免费预览已结束,剩余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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 图书馆卫生间管理规定
- 纪录片编剧服务协议
- 体育运动区房产交易样板
- 研发部门休假管理方案
- 学校地暖工程服务合同
- 旅游推广记者站管理办法
- 电力设施电子招投标竞争格局
- 精密仪器电焊工招聘合同
- 墙绘施工合同公园景观墙绘
- 房屋户外景观水景施工合同
- 新生儿红臀的护理课件
- 《上海市中学物理课程标准》试行稿
- 注塑车间规划方案
- 营养不良五阶梯治疗
- 【课件】铁及其化合物++第2课时++课件高一上学期化学人教版(2019)必修第一册
- 南通市2024届高三第一次调研测试(一模)生物试卷(含答案)
- 《茶叶销售技巧》课件
- 专项施工方案(模板工程及支撑体系专项施工方案)
- 1编译原理及实现课后题及答案
- 让阅读成为习惯家长会课件
- 居民自建桩安装告知书回执
评论
0/150
提交评论