10 Commits

Author SHA1 Message Date
b7de5a5c70 Supprimer exependu 2024-10-25 22:36:12 +02:00
5970b43f61 correction final historique partie 2024-10-25 22:35:10 +02:00
16f081c454 correctif bug save file 2024-10-25 18:43:33 +02:00
c0024eb101 Ajouter README.md 2024-10-24 23:53:23 +02:00
64baba6c61 Fix merge 2024-10-23 21:32:59 +02:00
159c83ea8d Added difficulty and comments 2024-10-23 21:01:29 +02:00
8877777c62 Commentaires 2024-10-15 12:27:04 +02:00
10c9aca59a Actualiser pendu.c 2024-10-15 12:16:52 +02:00
509db16917 Added comments 2024-10-15 11:59:29 +02:00
2fd6561591 Added difficulty 2024-10-15 11:32:49 +02:00
3 changed files with 93 additions and 24 deletions

23
README.md Normal file
View File

@@ -0,0 +1,23 @@
# TD3_DEV51_Qualite_Algo
###### par SCHIED Killian, LANDRIN Dylan et ROCHER Léo
## Exercice 4
### Complexité cyclomatique
Pour la complexité cyclomatique de chaque fonction nous avons calculé ceci :
| Fonction | Complexité Cyclomatique |
|---------------------------------------|-------------------------|
| `display_hangman(int tries)` | 7 |
| `save_party(char *status, const char *good_word, char try[])` | 3 |
| `sig_handler(int signum)` | 2 |
| `getWordByLength()` | 3 |
| `main()` | 13 |
### Utilisation de gprof
Le programme étant petit et fait appel à peu de fonction, l'utilisation de gprof ne nous permet pas d'obtenir d'information utile.
### Conclusion sur la qualité du code
Le code est fonctionnel et globalement efficace. On peut améliorer la quantité de commentaire et trouver un moyen de réduire la complexité cyclomatique du main.

88
pendu.c
View File

@@ -37,29 +37,29 @@ void display_hangman(int tries) {
} }
} }
<<<<<<< HEAD
<<<<<<< HEAD
/* /*
this function allow to save the last party this function allow to save the last party
Parameters: Parameters:
status -> state that save if the gamer win or lose the party status -> state that save if the gamer win or lose the party
good_word -> the word to guess good_word -> the word to guess
try -> the letters try by the gamer try -> the wrong letters try by the gamer
cpt_try -> the try's table size
good_try -> the good letters try by the gamer
cpt_good_try -> the good_try's table size
*/ */
void save_party(char * status, const char * good_word, char try[]) { void save_party(char * status, const char * good_word, char try[], int cpt_try, char good_try[], int cpt_good_try) {
time_t t; time_t t;
time(&t); //stock the current time time(&t); //stock the current time
char * date; char * date;
date = ctime(&t); //stock the current time format as: day, month, number of the month, hour, year date = ctime(&t); //stock the current time format as: day, month, number of the month, hour, year
FILE* fichier = fopen("save_party.txt", "w"); FILE* fichier = fopen("save_party.txt", "a");
if (fichier != NULL) if (fichier != NULL)
{ {
fputs("Date and time: ", fichier); fputs("Date and time: ", fichier);
fputs(date,fichier); fputs(date,fichier);
fputs("\n",fichier);
fputs("Status: ", fichier); fputs("Status: ", fichier);
fputs(status,fichier); fputs(status,fichier);
@@ -70,20 +70,22 @@ void save_party(char * status, const char * good_word, char try[]) {
fputs("\n",fichier); fputs("\n",fichier);
fputs("tried letters: ", fichier); fputs("tried letters: ", fichier);
for (int i = 0; i < sizeof(try); i++) { for (int i = 0; i < cpt_try; i++) {
fputc(try[i],fichier); fputc(try[i],fichier);
} }
fputs("\n",fichier); fputs("\n",fichier);
fclose(fichier); // On ferme le fichier qui a été ouvert fputs("guessed letters: ", fichier);
for (int i = 0; i < cpt_good_try; i++) {
fputc(good_try[i],fichier);
}
fputs("\n",fichier);
fputs("\n",fichier);
fclose(fichier); // Close the opened file
}
} }
=======
void sig_handler(int signum){
printf("\ntime out\n");
exit (1);
>>>>>>> b4f25a5 (ajout du cooldown sur le scanf)
=======
/* this function display time out when user does nothing during 30s and verify signal*/ /* this function display time out when user does nothing during 30s and verify signal*/
void sig_handler(int signum){ void sig_handler(int signum){
if (signum == SIGALRM){ if (signum == SIGALRM){
@@ -91,17 +93,60 @@ void sig_handler(int signum){
printf("\ntime out\n"); printf("\ntime out\n");
exit (1); exit (1);
} }
>>>>>>> 83066e1 (ajout des commentaires.) }
/*
getWordByLength() function adds the possibility to the user to choose how many letters maximum the word to guess can contains.
Returns:
A random word from the words list that correspond to the user input
*/
const char* getWordByLength(){
int maxLetters;
printf("Difficulté - Entrez le nombre de lettres maximum à deviner : ");
scanf(" %d", &maxLetters);
const char *newWords[MAX_WORDS];
int wordsFound = 0;
for (int i = 0; i < MAX_WORDS; i++) {
if(strlen(words[i]) <= maxLetters){
newWords[wordsFound] = words[i];
wordsFound++;
}
}
if(wordsFound==0){
return "";
}
const char *word = newWords[rand() % wordsFound];
/* SECOND WORD TO GUESS (NOT WORKING)
wordsFound = 0;
for (int i = 0; i < MAX_WORDS; i++) {
if(strlen(words[i]) <= maxLetters-strlen(word)){
newWords[wordsFound] = words[i];
wordsFound++;
}
}
if(wordsFound != 0){
word = (const char*) strcat((char *) word, newWords[rand() % wordsFound]);
}*/
return word;
} }
int main() { int main() {
srand(time(NULL)); srand(time(NULL));
const char *word = words[rand() % MAX_WORDS]; const char *word = getWordByLength();
if(word==""){
printf("Aucun mot n'a été trouvé.");
return 1;
}
int word_length = strlen(word); int word_length = strlen(word);
char guessed[word_length]; char guessed[word_length];
int tries = 0; int tries = 0;
int guessed_correctly = 0; int guessed_correctly = 0;
char try[MAX_TRIES]; //save the carcater try char try[MAX_TRIES]; //save the carcater false
char good_try[word_length]; //save the carcater good
int cpt = 0;
signal(SIGALRM,sig_handler);
signal(SIGALRM,sig_handler); signal(SIGALRM,sig_handler);
@@ -121,7 +166,6 @@ int main() {
scanf(" %c", &guess); scanf(" %c", &guess);
int found = 0; int found = 0;
for (int i = 0; i < word_length; i++) { for (int i = 0; i < word_length; i++) {
@@ -129,7 +173,6 @@ int main() {
if (guessed[i] == '_') { if (guessed[i] == '_') {
guessed[i] = guess; guessed[i] = guess;
guessed_correctly++; guessed_correctly++;
try[tries] = guess;
} }
found = 1; found = 1;
} }
@@ -138,16 +181,19 @@ int main() {
if (!found) { if (!found) {
try[tries] = guess; try[tries] = guess;
tries++; tries++;
}else{
good_try[cpt] = guess;
cpt++;
} }
} }
if (guessed_correctly == word_length) { if (guessed_correctly == word_length) {
printf("Félicitations ! Vous avez deviné le mot : %s\n", word); printf("Félicitations ! Vous avez deviné le mot : %s\n", word);
save_party("Win", word, try); save_party("Win", word, try, tries, good_try, cpt);
} else { } else {
printf("Désolé, vous avez perdu. Le mot était : %s\n", word); printf("Désolé, vous avez perdu. Le mot était : %s\n", word);
display_hangman(MAX_TRIES); display_hangman(MAX_TRIES);
save_party("Lose", word, try); save_party("Lose", word, try, tries, good_try, cpt);
} }
return 0; return 0;

Binary file not shown.