扎米亚京


私信TA

用户名:15332373513

访问量:2714

签 名:

等  级
排  名 26502
经  验 528
参赛次数 1
文章发表 3
年  龄 0
在职情况 学生
学  校 西安工业大学北方信息工程学院
专  业

  自我简介:

解题思路:
把从2到n中所有的数都列出来,然后从2开始,先划掉n内所有的2的倍数,然后每次从下一个剩下的数(必然是素数)开始,划掉n以内的所有倍数,最后剩下的,就都是素数。



注意事项:

char isprime[n+1];  //为了节省空间,定义为char型数组。

本方法采用二进制思想,若为素数,则数组对应值为1,最后输出数组值为1的角码。
虽为枚举法,但是,从2*i开始,每次加i,大大节省了时间。

参考代码:

#include <iostream>

using namespace std;


int main(int argc, char** argv) {

int n;

cin>>n;

char isprime[n+1];

for(int i=2;i<=n;i++)

isprime[i]=1;

for(int i=2;i<=n;++i){

if(isprime[i])

for(int j=2*i;j<=n;j+=i)

isprime[j]=0;

}

for(int i=2;i<=n;++i)

if(isprime[i])

cout<<i<<endl;

return 0;

}


 

0.0分

0 人评分

看不懂代码?想转换其他语言的代码? 或者想问其他问题? 试试问问AI编程助手,随时响应你的问题:

编程语言转换

万能编程问答  

代码解释器

代码纠错

SQL生成与解释

  评论区