1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66
| #include <string.h>
#include <stdlib.h>
#include <stdio.h>
char *Calcul(char *LigneIn);
char *Calcul (char *LigneIn)
{
char *Retour;
int i, K;
i = 0;
K = 0;
Retour = malloc (2 * strlen (LigneIn) + 1);
while (LigneIn[i] != 0)
{
if (LigneIn[i] != LigneIn[i + 1])
{
Retour[K] = '1';
Retour[K + 1] = LigneIn[i];
K = K + 2;
i++;
}
else if (LigneIn[i] != LigneIn[i + 2])
{
Retour[K] = '2';
Retour[K + 1] = LigneIn[i];
K = K + 2;
i = i + 2;
}
else
{
Retour[K] = '3';
Retour[K + 1] = LigneIn[i];
K = K + 2;
i = i + 3;
}
}
Retour[K] = 0;
return Retour;
}
int main (void)
#define NB_CHAINE 103
{
char *TAB[NB_CHAINE];
int ii, n, c;
printf ("Voici la suite de logique de nombre\n1\n11\n21\n1211\n111221\nDonnez le nombre de lignes supplémenataires que vous voulez dévoiler : ");
scanf ("%d", &n);
while (n < 0 || n > 99)
{
printf ("\nErreur de saisie, recommencez :");
scanf ("%d", &n);
}
TAB[0] = malloc (2);
strcpy (TAB[0], "1");
for (ii = 1; ii <= n+4; ii++)
{
TAB[ii] = Calcul (TAB[ii-1]);
}
for (ii = 0; ii <= n+4; ii++) printf ("\n%s", TAB[ii]);
getchar();
for (ii = 0; ii <= n+4 ; ii++)
free (TAB[ii]);
return 0;
} |