| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 477 人关注过本帖
标题:请帮忙看一下,错在哪里?
只看楼主 加入收藏
hcjiaozhi
Rank: 1
等 级:新手上路
帖 子:25
专家分:0
注 册:2010-10-11
结帖率:75%
收藏
已结贴  问题点数:20 回复次数:2 
请帮忙看一下,错在哪里?
请帮忙看一下,10201不是素数,错在哪里?
#include<stdio.h>
#include<math.h>
int Prime(int n)
{
    int i;
    if(n%2==0)
        return 0;
    for(i=3;i<sqrt(n);i+=2)
    {
        if(n%i==0)
            return 0;
    }
    return 1;
}
void main()
{
    int e,m,n;
   
    for(m=10000;m<1000000;m++)
    {
        int a=m%10,b=((m-a)%100)/10,c=m/10000,d=(m-c*10000)/1000;
        e=Prime(m);
        if((a==c)&&(b==d)&&(e==1))
        {
            n=m;
            printf("%d\t ",n);            
        }
    }
    printf("\n");
}
图片附件: 游客没有浏览图片的权限,请 登录注册
搜索更多相关主题的帖子: 10000 include return 
2013-05-10 22:39
Juson
Rank: 4
等 级:业余侠客
帖 子:70
专家分:235
注 册:2013-4-8
收藏
得分:20 
for(i=3;i<sqrt(n);i+=2)  这里应该是 i<=sqrt(n)
2013-05-10 23:09
hcjiaozhi
Rank: 1
等 级:新手上路
帖 子:25
专家分:0
注 册:2010-10-11
收藏
得分:0 
回复 2楼 Juson
哦,原来是素数的判断有问题,谢谢!
2013-05-11 07:21
快速回复:请帮忙看一下,错在哪里?
数据加载中...
 
   



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

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