当前位置:   article > 正文

C++素数判定_c++判断素数

c++判断素数

质数_百度百科

定义:

素数(也成质数)是指在大于1的自然数中,除了1和它本身以外不再有其他因数的自然数。

1.

循环,将n除以2---n-1的整数,如果有其中一个数运算后的余数==0,n不为素数。

  1. #include<iostream>
  2. using namespace std;
  3. int main()
  4. {
  5. int n;
  6. cin>>n;
  7. bool flag=1;
  8. for(int i=2;i<n;i++){
  9. if(n%i==0){
  10. flag=0;
  11. break;
  12. }
  13. }
  14. if(flag)cout<<"YES";
  15. else cout<<"NO";
  16. return 0;
  17. }

2.

开根号

素数的因子只有1和它本身。 如果数c不是素数,则还有其他因子。设a,b.定有一个大于sqrt(c) ,一个小于sqrt(c) 。所以m一定有一个小于等于其平方根的因数,那么验证素数时就只需要验证到其平方根就可以了。

  1. #include<bits/stdc++.h>
  2. using namespace std;
  3. int main()
  4. {
  5. int n;
  6. cin>>n;
  7. bool flag=1;
  8. for(int i=2;i<sqrt(n);i++){
  9. if(n%i==0){
  10. flag=0;
  11. break;
  12. }
  13. }
  14. if(flag)cout<<"YES";
  15. else cout<<"NO";
  16. return 0;
  17. }

3.

埃氏筛法 

埃拉托斯特尼筛法_百度百科

要得到自然数n以内的全部素数,必须把不大于根号n的所有素数的倍数剔除,剩下的就是素数。 

  1. #include<bits/stdc++.h>
  2. using namespace std;
  3. bool flag[104];
  4. int main()
  5. {
  6. memset(flag,1,sizeof(flag));
  7. flag[1]=0;
  8. for(int i=2;i<=sqrt(100);i++){
  9. if(flag[i]){
  10. for(int j=2;j*i<=100;j++)flag[i*j]=0;
  11. }
  12. }
  13. for(int i=1;i<=100;i++){
  14. if(flag[i])cout<<"YES"<<endl;
  15. else cout<<"NO"<<endl;
  16. }
  17. return 0;
  18. }

4.

欧拉筛法: 

找到一个素数后,就将它的倍数标记为合数,也就是把它的倍数筛掉;如果一个数没有被比它小的素数筛掉,那它就是素数。

欧拉筛法复杂度为线性

代码详见例题。

例题:

素数个数

素数个数 - 洛谷

题目描述

求 1,2,⋯,N 中素数的个数。

输入格式

一行一个整数 N。

输出格式

一行一个整数,表示素数的个数。

题解:

数据范围是10的8次方,不能一个一个判断,要用欧拉筛法。

  1. #include<bits/stdc++.h>
  2. using namespace std;
  3. int n,ans,prime[5800001];
  4. bool visit[100000001];
  5. int main()
  6. {
  7. cin>>n;
  8. if(n<2){
  9. cout<<0;
  10. return 0;
  11. }
  12. for(register int i=2; i<=n;i++) {
  13. if(!visit[i])prime[++ans]=i;
  14. for(register int j=1; prime[j]*i<=n&&j<=ans; ++j) {
  15. visit[i*prime[j]]=true;
  16. if(!(i%prime[j])) break;
  17. }
  18. }
  19. //for(int i=1; i<=ans; ++i) printf("%d\n",prime[i]);
  20. cout<<ans;
  21. return 0;
  22. }

 

 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/盐析白兔/article/detail/75298
推荐阅读
相关标签
  

闽ICP备14008679号