| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 727 人关注过本帖
标题:有点小问题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
快速回复:有点小问题7??!
数据加载中...
 
   



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

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