Advertisement
mateuspl

uri1371

Apr 17th, 2015
271
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C 0.60 KB | None | 0 0
  1. #include <stdio.h>
  2.  
  3. void solve(int);
  4.  
  5. int main()
  6. {
  7.     int n;
  8.    
  9.     while (1)
  10.     {
  11.         scanf("%d", &n);
  12.  
  13.         if (!n) break;
  14.        
  15.         solve(n);
  16.         printf("\n");
  17.     }
  18. }
  19.  
  20. int max = 0;
  21. int num[5000];
  22.  
  23. void solve(int n)
  24. {
  25.     printf("1");
  26.  
  27.     if (n == 1)
  28.         return;
  29.  
  30.     int sum = 1;
  31.     int i = 4;
  32.  
  33.     if (max > 0)
  34.     {
  35.         for (i = 0; i < max && num[i] <= n; i++)
  36.             printf(" %d", num[i]);
  37.  
  38.         if (i < max && num[i] > n)
  39.             return;
  40.  
  41.         i = num[max - 1] + 1;
  42.     }
  43.  
  44.     for (; i <= n; i++)
  45.     {
  46.         double nSqrt = sqrt(i);
  47.  
  48.         if (nSqrt == (double) ((int) nSqrt))
  49.         {
  50.             printf(" %d", i);
  51.             num[max++] = i;
  52.         }
  53.     }
  54. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement