程序

Eros 2001-03-22 08:41:00
我们知道歌德巴赫猜想在一定的范围内已经通过了屡试法验证(任一大于6的偶数是两个不相等的质数的和),谁能告诉我一个公式或算法或程序,能够在有限位数中找到这两个质数,比如:我想知道16,18,24,28是由哪两个质数组成的
...全文
108 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
Kevin_qing 2001-03-22
  • 打赏
  • 举报
回复
to:Dreambird
你认为除了穷举还有其他办法吗?
如果真有一个公式的话,歌德巴赫猜想也就不叫歌德巴赫猜想了。



dreambird 2001-03-22
  • 打赏
  • 举报
回复
改来改去,还是老路子!
优化后还是同一个思路!
没创意!!!
Kevin_qing 2001-03-22
  • 打赏
  • 举报
回复
int IsPrime(int n);
效率太低
优化后增加%100以上。

int IsPrime(int n)
{
int nReturn = 0;
if (n <= 1) return 0;
int i;
if(!(n&1))
return 0;
for (i = 2; i <= n - 1; i+=2)
{
if (n % i == 0)
return 0;
}
return 1;

}
joke100 2001-03-22
  • 打赏
  • 举报
回复
GetTwoPart函数中有一些没用到的变量,去掉吧,看着太难受
void GetTwoPart(int min, int max)
{
int i, j;
for (i = min; i <= max; i++)
{
for (j = 2; j <= i / 2; j++)
if (IsPrime(j) && IsPrime(i - j))
printf("%d = %d + %d.\n", i, j, i-j);
}
}

joke100 2001-03-22
  • 打赏
  • 举报
回复
// 判断一个数是否为质数,返回值大于0则是
int IsPrime(int n)
{
int nReturn = 0;
if (n <= 0) return 0;
int i;
for (i = 2; i <= n - 1; i++)
if (n % i != 0)
nReturn = 1;

return nReturn;
}
// 在一定数值范围内逐个找出两个质数构成
void GetTwoPart(int min, int max)
{
int i, j, n, s ,p, f;
for (i = min; i <= max; i++)
{
for (j = 2; j <= i / 2; j++)
if (IsPrime(j) && IsPrime(i - j))
printf("%d = %d + %d.\n", i, j, i-j);
}
}

// 程序入口
main ()
{
GetTwoPart(1,1000);
}

16,471

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • Web++
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧