编写程序 大于6的整数都能被分成两个素数

用C++... 用 C++ 展开
 我来答
百度网友d01bcdb
2009-07-03 · TA获得超过352个赞
知道小有建树答主
回答量:277
采纳率:0%
帮助的人:260万
展开全部
介绍个思路给你,把这个整数分解为两个数的和,判断是否存在这两个数都为素数,存在返回真值,不存在返回假值。这样只要每个数的分解数都是素数,那不就可以证明论点了么,分析完毕。
程序如下:
#include<iostream>
#include<cmath>
using namespace std;
int fun(int n)
{
if(n==1||n==2)return 1;
for(int i=2;i<=sqrt(n);i++)
{
if(n%i==0)return 0;
}
return 1;
}
void main()
{
int num;
int count=0;
cout<<"输入一个大于6的整数的上限:"<<endl;
cin>>num;
for(int i=7;i<num;i++)
for(int j=1;j<=i/2;j++)
{
if(fun(j)&&fun(i-j))
{
cout<<i<<" 可以分解为两个素数:"<<j<<" "<<i-j<<endl;
count++;
break;
}

}
if(count==(num-6))cout<<"经验证,每个大于6的数都可以分解为两个素数的和。"<<endl;
else cout<<"存在不能分解为两个素数之和的大于6的整数。"<<endl;
}
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式