PAT1013 数素数
 题目
令Pi表示第i个素数。现任给两个正整数M≤N≤104,请输出PM到PN的所有素数。
 输入格式
输入在一行中给出M和N,其间以空格分隔。
 输出格式
输出从PM到PN_的所有素数,每 10 个数字占 1 行,其间以空格分隔,但行末不得有多余空格。
 输入样例
 输出样例
1 2 3
   | 11 13 17 19 23 29 31 37 41 43 47 53 59 61 67 71 73 79 83 89 97 101 103
   | 
 
 思路
求素数,要分清第n个素数和第n个数的区别。在输出同时还有控制10个数字一行,行末不得有多余空格。
 代码
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
   |  #include <iostream> #include <math.h> using namespace std; bool isPrime(int a) {     for(int i = 2; i <= sqrt(a); i++)     {         if(a % i == 0)         {             return false;         }     }     return true; }
  int main(int argc, char const *argv[]) {     int min,max,countP=0,count=0;     cin >> min >> max;     for(int t = 1; count <= max - min; t++)     {         if(isPrime(t))         {             if(countP >= min && countP <= max)             {                 count++;                 if((count % 10 == 0 && count != 0) || countP == max){                     cout << t << endl;                 }else{                     cout << t << " ";                 }                              }             countP++;         }     }     return 0; }
 
  |