第n小的质数
【题目描述】
输入一个正整数n,求第n小的质数。
【输入】
一个不超过10000的正整数n。
【输出】
第n小的质数。
【输入样例】
10
【输出样例】
29
请问哪里出了问题?
#include<iostream>
#include<cmath>
using namespace std;
int main()
{ int n,y=0,i,j;
cin>>n;
for(j=3;;j++)
{
if(j==2) break;
for(i=0;i<=sqrt(j);i++)
{if(j%i==0) continue;
else y++;
if(y==n)
{cout<<j<<endl;
break;}break;
}
}
return 0;
}
修改后的代码(正常情况下我会给修改方案,但这次的错误很难说清楚,你看注释理解一下吧):
#include<iostream>
#include<cmath>
using namespace std;
int main()
{ int n,y=0,i,j; // n=输入 y=计数,数质数 i=枚举因子 j=枚举可能的质数
cin>>n;
if(n==1){ //特判2
cout<<2<<endl;
return 0;
}
else y++;
for(j=3;;j+=2) //因为没有大于2的偶质数,所以枚举所有奇数就行了
{
// if(j==2) break; //这句多余
double sqrt_j=sqrt(j); //只运算一次sqrt,但如果想更快,在不溢出的情况下可以删掉这行,把循环条件改成i*i<=j
bool is_j_prime=1; //j是否为质数
if(j%2==0) is_j_prime=0; //特判2,因为只用判断所有的质数因子(判断2和所有奇数是较优方案)就行了
else for(i=3;i<=sqrt_j;i+=2) //从i==0开始会有除零错——后面有j%i //i=3和i+=2见上一行注释
if(j%i==0){
is_j_prime=0;
break;
}
if(is_j_prime) y++;
if(y==n)
{cout<<j<<endl;
break;}//break; //花括号外面这个break会使for循环第一次就结束
}
return 0;
}