免费预览已结束,剩余1页可下载查看
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
问题描述:欧拉证明素数有无穷多个。但每个整数能表示成4个素数之和吗?输入:每行输入一个整数N(N=10 000 000),它是你需要把它表示成4个素数之和的数。输出:对于每个输入行都有一个输出行,每行包含符合要求的4个素数。如果该素数不能表示为4个素数之和,那么输出一行不能。也可能有很多组解,任何合理的解都将被接受。输入样例: 输出样例:24 3 11 3 7363 7 13 134611 11 17 7代码:#include#include#includeusing namespace std;const int MAXLEN=10001;long modular_power1(long a,long r,long m)/求模幂ar mod m的值long d,t;d=1;t=a;while(r0)if(r%2)=1)d=(d*t)%m;r/=2;t=t*t%m;return d;/素数测试算法代码(Miller-Rabin素数测试算法)bool Miller_Rabin(long long a,long long n)long long d,t,bitnum,bit;bit=11;d=1;while(bit0)t=d;d=(d*d)%n;if(d=1)&(t!=1)&(t!=n-1)return true;if(bit&bitnum)!=0)d=(d*a)%n;bit=bit1;if(d!=1)return true;return false;void G_maini(int n,int *a,int *b)/用到上面的素数测试算法,此函数用来验证哥德巴赫猜想(每个大/于4的偶数都可以写成两个奇素数之和)int a1,a2,b1,b2,k;if(n3)|(n%2=1)coutErrorendl;elseif(n=4|n=6)*a=n/2;*b=n/2;elseif(n=8)*a=3;*b=5;else if(n=10)*a=3;*b=7;elsesrand(time(NULL);for(k=3;k=n-k-1)a1=(int(rand()%(n-k)+1);/随机选取a1if(Miller_Rabin(a1,n-k)continue;/第次Miller_Rabin素数测试elseb1=1;while(b1=1)|(b1=n-k-1)|b1=a1)b1=(int(rand()%(n-k)+1);/随机选取b1if(Miller_Rabin(b1,n-k)continue;/第次Miller_Rabin素数测试else*a=k;*b=n-k;break;elsea1=1;a2=1;while(a1=1)|(a1=k-1)a1=(int(rand()%k)+1);/随机选取a1while(a2=1)|(a2=n-k-1)a2=(int(rand()%(n-k)+1);/随机选取a2if(Miller_Rabin(a1,k)|Miller_Rabin(a2,n-k)continue;/第次Miller_Rabin素数测试elseb1=1;b2=1;while(b1=1)|(b1=k-1)|b1=a1)b1=(int(rand()%k)+1);/随机选取b1while(b2=1)|(b2=k-1)|b2=a1)b2=(int(rand()%(n-k)+1);/随机选取b2if(Miller_Rabin(b1,k)|Miller_Rabin(b2,n-k)continue;/第次Miller_Rabin素数测试else*a=k;*b=n-k;break;/return 0;bool prime(int n)/判断n是否是素数,若是则返回true int j; if(n=2)return true; if(n=1|n%2=0)return false; j=3; while(j=int(sqrt(long double(n) if(n%j=0)return false; j+=2; return true;void OddNumber(int num,int *a,int *b,int *a1,int *a2,int *b1,int *b2)/num为奇数时,这里的num/是待分解的数if(*a%2!=0)/当a是奇数时,则b为偶数,依据哥德巴赫猜想,b(大于)可以分解为两个素数之和;/如果a不能分解为两个素数之和,则num不能分解为四个素数之和if(prime(*a-2)/a-2是素数*a1=2,*a2=*a-2;/求b1和b2用哥德巴赫猜想G_maini(*b,b1,b2);else cout不能分解为四个素数;else/b是奇数,处理同上if(prime(*b-2)/b-2是素数*b1=2,*b2=*b-2;/求a1和a2用哥德巴赫猜想G_maini(*a,a1,a2);elsecoutnum;int a,b;int a1,a2,b1,b2;/分别存储分解后的数a=num/2;b=num-a;if(num%2=0)/num为偶数的情况/num为偶数的情况下分两种情况:、a=b为偶数,、a=b为奇数if(a%2=0)/1/依据哥德巴赫猜想G_maini(a,&a1,&a2);b1=a1,b2=a2;else/2 为奇数的情况考虑不全,当num=46时,应有解,程序得到的结果是错误的a=a-1;b=b+1;G_maini(a,&a1,&a2);G_maini(b,&b1,&b2);else/num为奇数的情况,这里说明一下,当num为奇数时,则可将num分解为一个奇数和一个偶数。/据哥德巴赫猜想可知,偶数可以分解为两个素数之和。由于偶素数只
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 信号设备组调工保密意识强化考核试卷含答案
- 锅炉管阀检修工成果转化竞赛考核试卷含答案
- (天一小高考)山西省2026届高三4月联考(素质评价)政治试卷(含答案详解)
- 轧花工安全宣传水平考核试卷含答案
- 母婴护理员岗前潜力考核试卷含答案
- 片基流延工安全文明考核试卷含答案
- 计算机及外部设备装配调试员持续改进水平考核试卷含答案
- 有色金属矿干燥工班组安全竞赛考核试卷含答案
- 纸箱纸盒制作工班组管理测试考核试卷含答案
- 装配式管廊施工安装验收试题及答案
- 妇产科省级重点专科汇报
- DB23∕T 3746-2024 建设项目临时使用草原地表土剥离利用技术规范
- 2025年党史知识竞赛测试题库附答案
- GB/T 46231.1-2025塑料聚氨酯原材料通用测试方法第1部分:近红外光谱法测定多元醇羟值
- 校医院药品安全知识培训课件
- 建筑物结构安全隐患应急预案
- 股骨粗隆间骨折个案护理查房
- 车床导轨测量课件
- 队地质资料管理办法
- (人教PEP版)小学英语四年级下册 Unit 2单元测试及答案01
- 食品安全培训考试题库及详解
评论
0/150
提交评论