标题:有点小问题7??!
只看楼主
卧龙先生
Rank: 1
等 级:新手上路
帖 子:77
专家分:0
注 册:2004-7-18
 问题点数:0 回复次数:1 
有点小问题7??!

#include "stdio.h" #include "math.h" int sushu(x) int x; {int i=2,k,flag=1; k=sqrt(x); while((i<=k)&&(flag==1)) {if(x%i==0) flag=0;i++;} return flag; }

main() {int a,b,c,s,i,j,e; for(c=6;c<=1000;c=c+2) {for(a=1;a<c;a=a+2) {if(sushu(a)==1) i=a; for(e=1;e<c;e=e+2) {if(sushu(e)==1) j=e; if(c==i+j) printf("%d+%d=%d\t",i,j,c); } } } }

小弟有一个程序,验证从6到1000的所有偶数都能表示成两个素数之和。但是,显示过程中有不少重复, 比如1+7=8,7+1=8,又有显示两次5+7=12,5+7=12这类问题。希望高手们帮我看看这程序那里有问题啊。指点一下改动的方法啊。

搜索更多相关主题的帖子: include return 
2004-07-30 16:45
乌鸦丘比特
Rank: 1
等 级:新手上路
威 望:2
帖 子:625
专家分:0
注 册:2004-7-19
得分:0 

你把a的搜索范围改为0到c/2就可以了,

还有e的循环我认为大可不必,直接判断sushu(c-a)就OK了


我喜欢创造,一只扑腾着翅膀向天空飞翔的乌鸦
2004-07-30 16:52



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-3728-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.047462 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved