解题思路:
旨在构造一个素数数组,利用素数判断一个数是不是素数, 如果是,则补充到素数数组中,以此类推就可以快速地找到 n以内所有素数。
注意事项:
参考代码:
#include<iostream> using namespace std; const int M=100001; unsigned long long a[M]={0}; int main() { int n; while(cin>>n) { a[0]=2,a[1]=3,a[2]=5,a[3]=7; int t=4; for(int i=11;;i+=2) { if(n<4||t==n) break; int ok=1; for(int j=1;a[j]*a[j]<=i;j++) //这里没必要考虑素数数组中所有的数,a[j]<=sqrt(i)即可 { if(i%a[j]==0) { ok=0; break; } } if(ok) a[t++]=i; } unsigned long long sum=1; for(int i=0;i<n;i++) { sum*=a[i]; sum%=50000; } cout<<sum<<endl; } return 0; }
0.0分
0 人评分
【计算球体积】 (C语言代码)浏览:984 |
IP判断 (C++代码)浏览:671 |
C语言程序设计教程(第三版)课后习题9.6 (C语言代码)浏览:567 |
川哥的吩咐 (C++代码)浏览:1007 |
C语言训练-最大数问题 (C语言代码)浏览:633 |
简单的a+b (C语言代码)浏览:681 |
用筛法求之N内的素数。 (C语言代码)浏览:646 |
C语言程序设计教程(第三版)课后习题6.8 (C语言代码)浏览:522 |
Hello, world! (C++代码)浏览:1743 |
剪刀石头布 (C++代码)浏览:1699 |