Skip to content
Extraits de code Groupes Projets
Valider f14a9181 rédigé par Laurent Paucot's avatar Laurent Paucot
Parcourir les fichiers

algo fini et compile

parent fc1b6068
Aucune branche associée trouvée
Aucune étiquette associée trouvée
Aucune requête de fusion associée trouvée
...@@ -13,7 +13,7 @@ test.o : test.c run.h ...@@ -13,7 +13,7 @@ test.o : test.c run.h
clean : clean :
rm -rf *.o rm -rf *.o
mrproper: clean mrproper: clean
rm -rf run rm -rf run
run 0 → 100755
Fichier ajouté
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
#include <string.h> #include <string.h>
#include <fcntl.h>
#include <unistd.h>
#include <sys/stat.h>
int is_div(int number, int i) { // Vérifie si i est un diviseur de number. int is_div(int number, int i) { // Vérifie si i est un diviseur de number.
return (number % i == 0) ; // revoi 0 si le nombre n'est pas divisible par i et 1 si il est divisible return (number % i == 0) ; // revoi 0 si le nombre n'est pas divisible par i et 1 si il est divisible
...@@ -23,10 +26,12 @@ int* prime_divs(int number){ ...@@ -23,10 +26,12 @@ int* prime_divs(int number){
ptr[1] = 0; ptr[1] = 0;
int i; int i;
int len = 0;
for (i = 2; i < number; i++){ for (i = 2; i < number; i++){
if (is_prime(i) == 1 && is_div(number, i)){ if (is_prime(i) == 1 && is_div(number, i)){
ptr[i] = i; ptr[i] = i;
len++;
} }
else else
{ {
...@@ -35,7 +40,20 @@ int* prime_divs(int number){ ...@@ -35,7 +40,20 @@ int* prime_divs(int number){
} }
ptr[i] = -1; ptr[i] = -1;
return ptr; int *result;
result = malloc(sizeof(int)*len +sizeof(int));
int j =0;
for (int i = 0; ptr[i] != -1; i++)
{
if(ptr[i] != 0){
result[j] = ptr[i];
j++;
}
}
result[j] = -1;
free(ptr);
return result;
} }
...@@ -52,6 +70,41 @@ void afficherListe(int* tab) { // afficher la liste ...@@ -52,6 +70,41 @@ void afficherListe(int* tab) { // afficher la liste
} }
int run (char *input,char *output){
FILE *file1 = NULL;
FILE *file2 = NULL;
char chaine[15];
file1 = fopen(input,"r");
if (file1 == NULL){return -1;}
file2 = fopen(output,"w+");
if (file2 == NULL){
fclose(file1);
return -1;
}
while (fgets(chaine,15,file1) != NULL){
int *pr_divs = prime_divs(atoi(chaine));
fprintf(file2,"%s ",chaine);
for (int i = 0; pr_divs[i] != -1; i++)
{
fprintf(file2,"%d ",pr_divs[i]);
}
fputc('\n',file2);
}
fclose(file1);
fclose(file2);
return 0;
}
/* int main() { /* int main() {
// test pour is_div(int number, int i) // test pour is_div(int number, int i)
int number = 10 ; int number = 10 ;
......
0% Chargement en cours ou .
You are about to add 0 people to the discussion. Proceed with caution.
Terminez d'abord l'édition de ce message.
Veuillez vous inscrire ou vous pour commenter