This commit is contained in:
2025-10-15 16:49:12 +02:00
parent c9ba885e45
commit fa3fbab627
2 changed files with 136 additions and 0 deletions

View File

@@ -0,0 +1,39 @@
# Contrôle Machine - DEV5.1 Qualité algorithmique
```
$ gcc Racine.c
$ ./a.out
```
En théorie il devrait compiler, dommage que c'est que la théorie
Le main : remplit un table de taille CAPACITE de valeurs aléatoires [0-100]
## Exo1
*Note : La fonction racineCarre( ) ne renvoie pas -1 si ce n'est pas une racine entière*
*Note : racineCarreeTab( ) non plus*
## Exo2
Profiler : ne compile pas.
Complexité cyclomatique de racineCarree( ) : 3 (devrait être 4 avec le if racine non entière return -1).
Complexité cyclomatique de racineCarreeTab( ) : 2
Complexité algorithmique de racineCarree( ) : meilleur cas : O(1) (racine de 0 ou 1), dans le pire cas :
Complexité algorithmique de racineCarreeTab( ) : O(n) boucle n fois (n la taille du tableau)
## Exo3
Profiler : ne compile pas.
Complexité cyclomatique de TriSpecial( ) : 8
Complexité cyclomatique de racineCarreeEntiere( ) : 6 \
*Note : racineCarreeEntiere( ) est une sous fonction de TriSpecial( )*
Complexité algorithmique de TriSpecial( ) : O(n*2) boucle n fois (n la taille du tableau) 2 fois
Complexité algorithmique de racineCarreeEntiere( ) : O(n) boucle n fois (n la taille du tableau)

97
Racine.c Normal file
View File

@@ -0,0 +1,97 @@
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#define CAPACITE 3
int racineCarree(int nombre){
double calcul;
double difference;
if (nombre == 0 || nombre == 1){
return (nombre);
}
calcul = nombre;
do {
difference=calcul;
calcul=0.5 * (calcul + nombre / calcul);
} while (calcul != difference);
// devrait vérifier si c'est entier et return -1 si ce n'est pas le cas
return (calcul);
}
void racineCarreeTab(tableau){
int i;
for(i=0;i<CAPACITE;i++){
tableau[i] = racineCarree(tableau[i]);
}
}
int racineCarreeEntiere(tableau){
int i, racineNonEntiere = 0
for(i=0;i<CAPACITE;i++){
if (tableau[i] == -1){
racineNonEntiere ++;
}
}
if ((racineNonEntiere /2) != 0){
return(1);
}else{
return(0);
}
}
void TriSpecial(tableau){
int i, racineNonEntiere = 0, sommeTableau = 0;
racineNonEntiere = racineCarreeEntiere(); //sous fonction pour chercher la quantite de racine carre non entiere
if (racineNonEntiere == 0){
for(i=0;i<CAPACITE;i++){
sommeTableau = sommeTableau + tableau[i];
}
for(i=0;i<CAPACITE;i++){
if ((i/2) != 0){
tableauTrie[i] = sommeTableau * tableau[i];
}else{
tableauTrie[i] = tableau[i];
}
}
}else{
for(i=0;i<CAPACITE;i++){
sommeTableau = sommeTableau + racineCarree(tableau[i]);
}
for(i=0;i<CAPACITE;i++){
if ((i/2) != 0){
tableauTrie[i] = sommeTableau * tableau[i];
}else{
tableauTrie[i] = racineCarree(tableau[i]);
}
}
}
}
int main(void) {
int tableau[CAPACITE];
int i;
srand(time(NULL));
for(i=0;i<CAPACITE;i++){
tableau[i]=(rand()%101);
}
for(i=0;i<CAPACITE;i++){
printf("%d ", tableau[i]);
}
printf("\n");
racineCarreeTab(tableau);
for(i=0;i<CAPACITE;i++){
printf("%d ", tableau[i]);
}
return EXIT_SUCCESS;
}