在给定范围之间有多少素数? C ++

时间:2014-01-18 00:21:43

标签: c++ algorithm primes

所以,我做了这个小程序。它提供了所有正确的输出,但是当它上传到在线评判时,它会让我离开时间限制超过。关于如何提高效率的任何想法?

这是我的代码。

int const MAX = 1000001;  
#include<iostream> 
#include<string>
#include<cmath>

using namespace std;

int main()
{
    int count = 0, array[MAX], a, b, pi = 0;  
    bool end = false;

for(int i = 1; i <= MAX; i++)
{
    count = 0;
    for(int j = 2; j <= sqrt(i); j++)
    {
        if(i % j == 0)
        {
            array[i]=0;
            count++;
            break;
        }
    }
    if(count == 0 && i != 1){
        array[i]=1;
    }
}

do {
    cin >> a >> b;
    pi = 0;
    if ((a == 0) && (b == 0)) {
        end = true;
        break;
    }
    else {
        for (int i = a; i <= b; i++) {
            if (array[i] == 1) {
                pi ++;
            }
        }
        cout << pi << endl;
    }
} while (end == false);
cout << endl;

return 0;
}

1 个答案:

答案 0 :(得分:1)

您可以考虑使用Sieve of Eratosthenes。它是一种有效的素数生成算法。