From 48cccb4f17ee644c5dda2186f8288f12c14f2999 Mon Sep 17 00:00:00 2001 From: Dimitrijevic Date: Tue, 15 Oct 2024 11:30:46 +0200 Subject: [PATCH 1/5] Ajout chrono et score --- .vscode/tasks.json | 28 ++++++++++ pendu.c | 125 +++++++++++++++++++++++++++++---------------- 2 files changed, 110 insertions(+), 43 deletions(-) create mode 100644 .vscode/tasks.json diff --git a/.vscode/tasks.json b/.vscode/tasks.json new file mode 100644 index 0000000..08d9005 --- /dev/null +++ b/.vscode/tasks.json @@ -0,0 +1,28 @@ +{ + "tasks": [ + { + "type": "cppbuild", + "label": "C/C++: gcc build active file", + "command": "/usr/bin/gcc", + "args": [ + "-fdiagnostics-color=always", + "-g", + "${file}", + "-o", + "${fileDirname}/${fileBasenameNoExtension}" + ], + "options": { + "cwd": "${fileDirname}" + }, + "problemMatcher": [ + "$gcc" + ], + "group": { + "kind": "build", + "isDefault": true + }, + "detail": "Task generated by Debugger." + } + ], + "version": "2.0.0" +} \ No newline at end of file diff --git a/pendu.c b/pendu.c index 1b0cfd6..5db68b1 100644 --- a/pendu.c +++ b/pendu.c @@ -2,24 +2,18 @@ #include #include #include +#include +#include +#include #define MAX_WORDS 14 #define MAX_TRIES 6 const char *words[MAX_WORDS] = { - "programmation", - "ordinateur", - "langage", - "jeu", - "algorithmique", - "fontainebleau", - "koala", - "anticonstitutionnellement", - "code", - "canard", - "gyroscope", - "periclitation", - "susurrer", + "programmation", "ordinateur", "langage", "jeu", + "algorithmique", "fontainebleau", "koala", + "anticonstitutionnellement", "code", "canard", + "gyroscope", "periclitation", "susurrer", "eclesiastique" }; @@ -35,47 +29,92 @@ void display_hangman(int tries) { } } +void alarm_handler(int sig) { + printf("\nTrop tard ! Vous avez dépassé les 30 secondes.\n"); + exit(1); +} + int main() { srand(time(NULL)); - const char *word = words[rand() % MAX_WORDS]; - int word_length = strlen(word); - char guessed[word_length]; - int tries = 0; - int guessed_correctly = 0; - for (int i = 0; i < word_length; i++) { - guessed[i] = '_'; - } - guessed[word_length] = '\0'; - - while (tries < MAX_TRIES && guessed_correctly < word_length) { - printf("\nMot à deviner : %s\n", guessed); - display_hangman(tries); - char guess; - printf("Entrez une lettre : "); - scanf(" %c", &guess); - int found = 0; + while (1) { + const char *word = words[rand() % MAX_WORDS]; + int word_length = strlen(word); + char guessed[word_length + 1]; + int tries = 0; + int guessed_correctly = 0; + int score = 0; for (int i = 0; i < word_length; i++) { - if (word[i] == guess) { - if (guessed[i] == '_') { - guessed[i] = guess; - guessed_correctly++; + guessed[i] = '_'; + } + guessed[word_length] = '\0'; + + signal(SIGALRM, alarm_handler); + + while (tries < MAX_TRIES && guessed_correctly < word_length) { + printf("\nMot à deviner : %s\n", guessed); + display_hangman(tries); + char guess; + + alarm(30); + printf("Entrez une lettre (ou 'q' pour quitter) : "); + scanf(" %c", &guess); + alarm(0); + + if (guess == 'q') { + printf("Vous avez quitté le jeu. À bientôt !\n"); + return 0; + } + + if (!isalpha(guess)) { + printf("Veuillez entrer une lettre valide.\n"); + continue; + } + + guess = tolower(guess); + int found = 0; + + // Démarrer le chronomètre + clock_t start_time = clock(); + + for (int i = 0; i < word_length; i++) { + if (word[i] == guess) { + if (guessed[i] == '_') { + guessed[i] = guess; + guessed_correctly++; + // Calculer le score basé sur le temps + score += 1000 - (clock() - start_time) * 1000 / CLOCKS_PER_SEC; // Bonus pour le temps + } + found = 1; } - found = 1; + } + + if (!found) { + tries++; + score -= 200; // Malus pour une mauvaise réponse } } - if (!found) { - tries++; + if (guessed_correctly == word_length) { + printf("Félicitations ! Vous avez deviné le mot : %s\n", word); + // Bonus si trouvé en moins de 3 essais + if (tries < 3) { + score += 500; + } + } else { + printf("Désolé, vous avez perdu. Le mot était : %s\n", word); + display_hangman(MAX_TRIES); } - } - if (guessed_correctly == word_length) { - printf("Félicitations ! Vous avez deviné le mot : %s\n", word); - } else { - printf("Désolé, vous avez perdu. Le mot était : %s\n", word); - display_hangman(MAX_TRIES); + printf("Votre score est : %d\n", score); + + char play_again; + printf("Voulez-vous jouer à nouveau ? (o/n) : "); + scanf(" %c", &play_again); + if (tolower(play_again) != 'o') { + break; + } } return 0; -- 2.47.0 From 3cd2277c5d8b4f3bb6884cc1b85d2d3d022cb0b0 Mon Sep 17 00:00:00 2001 From: Dimitrijevic Date: Tue, 15 Oct 2024 11:36:53 +0200 Subject: [PATCH 2/5] Readme --- Readme.MD | 9 +++++++++ 1 file changed, 9 insertions(+) create mode 100644 Readme.MD diff --git a/Readme.MD b/Readme.MD new file mode 100644 index 0000000..7c706c0 --- /dev/null +++ b/Readme.MD @@ -0,0 +1,9 @@ +TD 3 + +Ajout des fonctionnalités + +Hugo : + +Pour ajouter les chronomètre, j'ai utilisé une clock pour compter les 30 secondes etre les réponses + +Lyanis : \ No newline at end of file -- 2.47.0 From 11f44821bf1a13e0208cd74a3af2d73f63ae4eba Mon Sep 17 00:00:00 2001 From: TheSinay Date: Thu, 24 Oct 2024 15:30:23 +0200 Subject: [PATCH 3/5] a essayer --- .vscode/launch.json | 7 ++ .vscode/tasks.json | 20 +++++ pendu.c | 199 +++++++++++++++++++++++++++++--------------- 3 files changed, 157 insertions(+), 69 deletions(-) create mode 100644 .vscode/launch.json diff --git a/.vscode/launch.json b/.vscode/launch.json new file mode 100644 index 0000000..5c7247b --- /dev/null +++ b/.vscode/launch.json @@ -0,0 +1,7 @@ +{ + // Use IntelliSense to learn about possible attributes. + // Hover to view descriptions of existing attributes. + // For more information, visit: https://go.microsoft.com/fwlink/?linkid=830387 + "version": "0.2.0", + "configurations": [] +} \ No newline at end of file diff --git a/.vscode/tasks.json b/.vscode/tasks.json index 08d9005..a52b3e9 100644 --- a/.vscode/tasks.json +++ b/.vscode/tasks.json @@ -17,6 +17,26 @@ "problemMatcher": [ "$gcc" ], + "group": "build", + "detail": "Task generated by Debugger." + }, + { + "type": "cppbuild", + "label": "C/C++: cl.exe build active file", + "command": "cl.exe", + "args": [ + "/Zi", + "/EHsc", + "/nologo", + "/Fe${fileDirname}\\${fileBasenameNoExtension}.exe", + "${file}" + ], + "options": { + "cwd": "${fileDirname}" + }, + "problemMatcher": [ + "$msCompile" + ], "group": { "kind": "build", "isDefault": true diff --git a/pendu.c b/pendu.c index 5db68b1..5df3c3e 100644 --- a/pendu.c +++ b/pendu.c @@ -17,6 +17,7 @@ const char *words[MAX_WORDS] = { "eclesiastique" }; +// Fonction pour afficher le pendu void display_hangman(int tries) { switch (tries) { case 0: printf(" ----\n | |\n |\n |\n |\n |\n--------\n"); break; @@ -29,85 +30,145 @@ void display_hangman(int tries) { } } +// Fonction pour gérer le signal d'alarme void alarm_handler(int sig) { printf("\nTrop tard ! Vous avez dépassé les 30 secondes.\n"); exit(1); } +// Fonction pour filtrer les mots selon la taille maximale +int filter_words(const char *filtered_words[], int max_word_length) { + int count = 0; + for (int i = 0; i < MAX_WORDS; i++) { + if (strlen(words[i]) <= max_word_length) { + filtered_words[count++] = words[i]; + } + } + return count; +} + +// Fonction pour choisir plusieurs mots uniques aléatoirement +void choose_random_words(const char *filtered_words[], int num_filtered_words, char *result, int max_length) { + int total_length = 0; + while (total_length < max_length) { + int index = rand() % num_filtered_words; + const char *chosen_word = filtered_words[index]; + + if (total_length + strlen(chosen_word) + 1 > max_length) { + break; + } + + strcat(result, chosen_word); + total_length += strlen(chosen_word); + + if (total_length < max_length) { + strcat(result, " "); + total_length++; + } + } +} + +// Fonction pour initialiser le mot deviné avec des underscores +void initialize_guessed_word(char guessed[], const char *word, int word_length) { + for (int i = 0; i < word_length; i++) { + guessed[i] = (word[i] == ' ') ? ' ' : '_'; // Gérer les espaces + } + guessed[word_length] = '\0'; +} + +// Fonction pour traiter chaque saisie de l'utilisateur +int handle_guess(char guess, const char *word, char guessed[], int word_length, int *score) { + int found = 0; + clock_t start_time = clock(); + + for (int i = 0; i < word_length; i++) { + if (word[i] == guess) { + if (guessed[i] == '_') { + guessed[i] = guess; + found = 1; + *score += 1000 - (clock() - start_time) * 1000 / CLOCKS_PER_SEC; + } + } + } + + return found; +} + +// Fonction principale pour jouer une partie +int play_game(const char *word, int word_length) { + char guessed[word_length + 1]; + int tries = 0; + int guessed_correctly = 0; + int score = 0; + + initialize_guessed_word(guessed, word, word_length); + + while (tries < MAX_TRIES && guessed_correctly < word_length) { + printf("\nMot à deviner : %s\n", guessed); + display_hangman(tries); + char guess; + + alarm(30); + printf("Entrez une lettre (ou 'q' pour quitter) : "); + scanf(" %c", &guess); + alarm(0); + + if (guess == 'q') { + printf("Vous avez quitté le jeu. À bientôt !\n"); + return 0; + } + + if (!isalpha(guess)) { + printf("Veuillez entrer une lettre valide.\n"); + continue; + } + + guess = tolower(guess); + int found = handle_guess(guess, word, guessed, word_length, &score); + + if (!found) { + tries++; + score -= 200; // Malus pour une mauvaise réponse + } else { + guessed_correctly += found; + } + } + + if (guessed_correctly == word_length) { + printf("Félicitations ! Vous avez deviné le mot : %s\n", word); + if (tries < 3) { + score += 500; + } + } else { + printf("Désolé, vous avez perdu. Le mot était : %s\n", word); + display_hangman(MAX_TRIES); + } + + printf("Votre score est : %d\n", score); + return score; +} + int main() { srand(time(NULL)); while (1) { - const char *word = words[rand() % MAX_WORDS]; + int max_word_length; + printf("Entrez la taille maximale des mots à deviner : "); + scanf("%d", &max_word_length); + + const char *filtered_words[MAX_WORDS]; + int num_filtered_words = filter_words(filtered_words, max_word_length); + + if (num_filtered_words == 0) { + printf("Aucun mot ne correspond à cette taille maximale.\n"); + continue; + } + + char word[256] = ""; + choose_random_words(filtered_words, num_filtered_words, word, max_word_length); int word_length = strlen(word); - char guessed[word_length + 1]; - int tries = 0; - int guessed_correctly = 0; - int score = 0; - - for (int i = 0; i < word_length; i++) { - guessed[i] = '_'; - } - guessed[word_length] = '\0'; - - signal(SIGALRM, alarm_handler); - - while (tries < MAX_TRIES && guessed_correctly < word_length) { - printf("\nMot à deviner : %s\n", guessed); - display_hangman(tries); - char guess; - - alarm(30); - printf("Entrez une lettre (ou 'q' pour quitter) : "); - scanf(" %c", &guess); - alarm(0); - - if (guess == 'q') { - printf("Vous avez quitté le jeu. À bientôt !\n"); - return 0; - } - - if (!isalpha(guess)) { - printf("Veuillez entrer une lettre valide.\n"); - continue; - } - - guess = tolower(guess); - int found = 0; - - // Démarrer le chronomètre - clock_t start_time = clock(); - - for (int i = 0; i < word_length; i++) { - if (word[i] == guess) { - if (guessed[i] == '_') { - guessed[i] = guess; - guessed_correctly++; - // Calculer le score basé sur le temps - score += 1000 - (clock() - start_time) * 1000 / CLOCKS_PER_SEC; // Bonus pour le temps - } - found = 1; - } - } - - if (!found) { - tries++; - score -= 200; // Malus pour une mauvaise réponse - } - } - - if (guessed_correctly == word_length) { - printf("Félicitations ! Vous avez deviné le mot : %s\n", word); - // Bonus si trouvé en moins de 3 essais - if (tries < 3) { - score += 500; - } - } else { - printf("Désolé, vous avez perdu. Le mot était : %s\n", word); - display_hangman(MAX_TRIES); - } - - printf("Votre score est : %d\n", score); + printf("%s",word) + int score = play_game(word, word_length); char play_again; printf("Voulez-vous jouer à nouveau ? (o/n) : "); -- 2.47.0 From 227f77d89d978be545da0203294fc6c8f2011f0f Mon Sep 17 00:00:00 2001 From: Yanis DARIUS Date: Thu, 24 Oct 2024 15:44:59 +0200 Subject: [PATCH 4/5] Actualiser pendu.c --- pendu.c | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/pendu.c b/pendu.c index 5df3c3e..6041159 100644 --- a/pendu.c +++ b/pendu.c @@ -109,11 +109,11 @@ int play_game(const char *word, int word_length) { char guess; alarm(30); - printf("Entrez une lettre (ou 'q' pour quitter) : "); + printf("Entrez une lettre (ou '1' pour quitter) : "); scanf(" %c", &guess); alarm(0); - if (guess == 'q') { + if (guess == '1') { printf("Vous avez quitté le jeu. À bientôt !\n"); return 0; } @@ -167,7 +167,7 @@ int main() { char word[256] = ""; choose_random_words(filtered_words, num_filtered_words, word, max_word_length); int word_length = strlen(word); - printf("%s",word) + printf("%s",word); int score = play_game(word, word_length); char play_again; -- 2.47.0 From c49ca7d7d12057f8ab025b1b4c776fa1f30b19ca Mon Sep 17 00:00:00 2001 From: TheSinay Date: Thu, 24 Oct 2024 15:49:13 +0200 Subject: [PATCH 5/5] fix --- pendu.c | 1 - 1 file changed, 1 deletion(-) diff --git a/pendu.c b/pendu.c index 6041159..ba7f03a 100644 --- a/pendu.c +++ b/pendu.c @@ -167,7 +167,6 @@ int main() { char word[256] = ""; choose_random_words(filtered_words, num_filtered_words, word, max_word_length); int word_length = strlen(word); - printf("%s",word); int score = play_game(word, word_length); char play_again; -- 2.47.0