求助杭电ACM2012题

#include<stdio.h>#include<math.h>intmain(){intx,y,n,m,i,sum;while(scanf("%d%d",&x,&y)... #include<stdio.h>
#include<math.h>
int main()
{
int x,y,n,m,i,sum;
while(scanf("%d %d",&x,&y)!=EOF)
{if(x==0&&y==0)break;
for(i=x;i<=y;i++)
{
sum=i*i+i+41;
for(n=2,m=0;n<=sqrt(sum);n++)
{if(sum%n!=0)m++;}

}
if(m==n-2)printf("OK\n");
else printf("Sorry\n");

}
return 0;
}

题目 http://acm.hdu.edu.cn/showproblem.php?pid=2012
无论输入哪两个数字都是OK,不知道哪里错了,请教各位大牛
展开
 我来答
kaixingui2012
2011-10-30 · TA获得超过4.2万个赞
知道大有可为答主
回答量:1.4万
采纳率:81%
帮助的人:6427万
展开全部
优化了一下你的程序,你试看吧!
#include<stdio.h>
#include<math.h>
int main()
{
int x,y,n,m,i,sum;
while(1) //题目只要求x,y都是0时才退出
{
scanf("%d %d",&x,&y) ;
if(x==0&&y==0)break;
else
if ( x > y )
{
printf("Sorry\n");
continue ;
}
m=0;
for(i=x;i<=y;i++)
{
sum=i*i+i+41;

for(n=2;n<=(int)sqrt(sum);n++)
{
if(sum%n==0) //能整除n,说明有因数,则sum不是素数
{
m=1;break;
}
}
if ( m ) //有因数,不是素数
break;
}
if(m)
printf("Sorry\n");
else
printf("OK\n");
}
system("pause");
return 0;
}
sxsy556
2011-10-30 · TA获得超过1284个赞
知道小有建树答主
回答量:1037
采纳率:0%
帮助的人:654万
展开全部
#include<stdio.h>
#include<math.h>
int main()
{
int x,y,n,m,i,sum;
while(scanf("%d%d",&x,&y)!=EOF)
{if(x==0&&y==0)break;
for(i=x;i<=y;i++)
{
sum=i*i+i+41;
for(n=2,m=0;n<=(int)sqrt(sum);n++)
{if(sum%n!=0) m++;}

}
if(m==n-2) printf("OK\n");
else printf("Sorry\n");

}
getch();
return 0;
}
这次你再输入9 8 试试
说明是得到的那个sum是个素数啊
更多追问追答
追问
还是错误的答案
追答
报什么错误答案,这好像就是个素数判定啊
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
shangtian1216
2011-10-30
知道答主
回答量:22
采纳率:0%
帮助的人:16.7万
展开全部
哥们,你把这一行:while(scanf("%d %d",&x,&y)!=EOF)中两个%d的空格删了再试试
追问
删了,还是一直输出OK
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式