Zoe_yuyang 2018-12-21 11:56 采纳率: 50%
浏览 3406

新手求助:第n小的质数

第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;
}
  • 写回答

1条回答 默认 最新

  • _ZGq 2018-12-21 04:52
    关注
    1. 注意,sqrt的时间复杂度为log2(n),不要每次都重新计算。
    2. j一开始就等于3了,j怎么可能等于2呢?其他地方也没有退出循环的出口啊!

    修改后的代码(正常情况下我会给修改方案,但这次的错误很难说清楚,你看注释理解一下吧):

    #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;
    }
    
    评论

报告相同问题?

悬赏问题

  • ¥15 如何在scanpy上做差异基因和通路富集?
  • ¥20 关于#硬件工程#的问题,请各位专家解答!
  • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
  • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
  • ¥30 截图中的mathematics程序转换成matlab
  • ¥15 动力学代码报错,维度不匹配
  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 報錯:Person is not mapped,如何解決?
  • ¥15 c++头文件不能识别CDialog