Advertisement
Le_BuG63

Untitled

Jul 4th, 2014
241
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C 2.87 KB | None | 0 0
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include <ctype.h>
  4. #include <string.h>
  5.  
  6. enum    suitType_e
  7. {
  8.     UNKNOW,
  9.     CONSTANT,
  10.     GEOMETRIC,
  11.     ARITHMETIC
  12. };
  13.  
  14. typedef enum suitType_e suitType_t;
  15.  
  16. // Cette fonction sert à récuperer les nombres dans une chaîne de caractères
  17. int         get_numbers(char *pStrOperation, float *fTabSuit)
  18. {
  19.     unsigned int    k = 0;
  20.     char            *pch = NULL;
  21.  
  22.     pch = strtok(pStrOperation, ", -+");
  23.  
  24.     while(pch != NULL)
  25.     {
  26.         fTabSuit[k++] = atof(pch);
  27.  
  28.         pch = strtok(NULL, ", -+");
  29.     }
  30.  
  31.     return k;
  32. }
  33.  
  34. // Cette fonction analyse le type de suite que l'utilisateur a rentrée
  35. suitType_t  get_suit_type(float *fTabSuit, size_t nNumbersInTab)
  36. {
  37.     size_t  index;
  38.     float   tmp;
  39.     int     err = 0;
  40.  
  41.     tmp = fTabSuit[0];
  42.     for(index = 1; index < nNumbersInTab && err != 1; ++index) // On va vérifier si les nombres sont "CONSTANT"
  43.     {
  44.         if(tmp != fTabSuit[index])
  45.             err = 1;
  46.     }
  47.  
  48.     if(!err) return CONSTANT; err = 0;
  49.  
  50.     tmp = fTabSuit[1] - fTabSuit[0];
  51.     for(index = 2; index < nNumbersInTab && err != 1; ++index) // On va vérifier si les nombres sont "ARITHMETIC"
  52.     {
  53.         if(fTabSuit[index] - fTabSuit[index - 1] != tmp)
  54.             err = 1;
  55.     }
  56.  
  57.     if(!err) return ARITHMETIC; err = 0;
  58.  
  59.     tmp = fTabSuit[1] / fTabSuit[0];
  60.     for(index = 2; index < nNumbersInTab && err != 1; ++index) // On va vérifier si les nombres sont "GEOMETRIC"
  61.     {
  62.         if(fTabSuit[index] / fTabSuit[index - 1] != tmp)
  63.             err = 1;
  64.     }
  65.  
  66.     if(!err) return GEOMETRIC; err = 0;
  67.  
  68.     return UNKNOW;
  69. }
  70.  
  71. // Cette fonction continue la suite logique
  72. void        continue_suit(suitType_t suitType, float *fTabSuit, size_t numbersToPrint)
  73. {
  74.     size_t  index;
  75.     float   factor;
  76.     float   value;
  77.  
  78.     switch(suitType)
  79.     {
  80.     case ARITHMETIC:
  81.         factor  = fTabSuit[1] - fTabSuit[0];
  82.         value   = fTabSuit[0];
  83.  
  84.         for(index = 1; index < numbersToPrint; ++index)
  85.         {
  86.             printf("%.3f|", value);
  87.             value += factor;
  88.         }
  89.  
  90.         break;
  91.     case GEOMETRIC:
  92.         factor  = fTabSuit[1] / fTabSuit[0];
  93.         value   = fTabSuit[0];
  94.  
  95.         for(index = 1; index < numbersToPrint; ++index)
  96.         {
  97.             printf("%.3f|", value);
  98.             value *= factor;
  99.         }
  100.         break;
  101.  
  102.     case CONSTANT:
  103.         value = fTabSuit[0];
  104.         for(index = 1; index < numbersToPrint; ++index)
  105.             printf("%f|", value);
  106.         break;
  107.  
  108.     case UNKNOW:
  109.         printf("Il n'y a aucune suite logique trouvee.\n");
  110.         break;
  111.  
  112.     default:        // Ça ne devrait pas arriver, mais on sait jamais
  113.         break;
  114.     }
  115. }
  116.  
  117. int main(int argc, char *argv[])
  118. {
  119.     size_t      numbersToPrint = atoi(argv[1]);
  120.     size_t      sizeStringOperation = strlen(argv[2]);
  121.     float       *fTabSuit = malloc(sizeStringOperation);
  122.     int         nNumbers;
  123.     suitType_t  suitType;
  124.  
  125.     if(fTabSuit == NULL)
  126.     {
  127.         fprintf(stderr, "Erreur: memoire allouee indisponible");
  128.         return 1;
  129.     }
  130.  
  131.  
  132.     nNumbers = get_numbers(argv[2], fTabSuit);
  133.  
  134.     suitType = get_suit_type(fTabSuit, nNumbers);
  135.  
  136.     continue_suit(suitType, fTabSuit, numbersToPrint);
  137.  
  138.     free(fTabSuit);
  139.  
  140.     return 0;
  141. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement