鱼C论坛

 找回密码
 立即注册
查看: 1830|回复: 15

求素数问题,无所不能鱼油帮忙看看,非常感谢

[复制链接]
发表于 2015-11-14 16:20:42 | 显示全部楼层 |阅读模式
30鱼币
#include<stdio.h>
#include<math.h>
int main()
{int i,n,flag;
flag=1;       
for(n=2;n<=1000;n++)
{
for(i=2;i<=sqrt(n);i++)
        {
                if(n%i==0)
                        {
                        flag=0;
                        break;
                        }
        }
if(flag!=0)printf("%d\n",n);
}
}

我的目的是输出1000以内的素数,但是我感觉我上面的代码没问题,可是就是不能输出想要的结果,鱼油们帮忙看看,有鱼币送,谢谢各位。

最佳答案

查看完整内容

楼主忘了重新设置flag吧~第一层循环开始加上一句flag=1;就好啦~不然只要遇到第一个合数把flag变成0,flag就一直是0,后面的就都不会输出了~
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2015-11-14 16:20:43 | 显示全部楼层
楼主忘了重新设置flag吧~第一层循环开始加上一句flag=1;就好啦~不然只要遇到第一个合数把flag变成0,flag就一直是0,后面的就都不会输出了~
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2015-11-14 20:04:56 | 显示全部楼层
for(i=2;i<=sqrt(n);i++) 求教这一句什么意思,没看明白
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2015-11-14 21:00:24 | 显示全部楼层
bool bIsPrime(int n)
{
        if(n<2)
        {
                return false;
        }
        for (int i=2;i*i <= n;i++)
        {
                if(n % i == 0)
                {
                        return false;
                }
        }
        return true;
}
int main()
{

        for (int i=1;i<=1000;i++)
        {
                if (bIsPrime(i))
                {
                        printf("%d\r\n",i);
                }
        }
        system("pause");
        return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2015-11-15 10:10:03 | 显示全部楼层
0xcc 发表于 2015-11-14 17:11
楼主忘了重新设置flag吧~第一层循环开始加上一句flag=1;就好啦~不然只要遇到第一个合数把flag变成0,flag就 ...

#include<stdio.h>
#include<math.h>
int main()
{int i,n,flag;

for(n=3;n<=1000;n++)
{flag=1;       
for(i=2;i<=sqrt(n);i++)
        {
                if(n%i==0)
                        {
                        flag=0;
                        break;
                        }
        }
if(flag!=0)printf("%d\n",n);
}
}
改过之后确实是这一点错的,谢谢了,虽然是暴力算法,效率不怎么样,渣了点,但起码是自己琢磨出来的,先会这个再学其他算法。其实那个sqrt还是有些错误的,只不过在DEVc++这个编译器看不出来。最后真的非常感谢你。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2015-11-15 10:11:57 | 显示全部楼层
0xcc 发表于 2015-11-14 17:11
楼主忘了重新设置flag吧~第一层循环开始加上一句flag=1;就好啦~不然只要遇到第一个合数把flag变成0,flag就 ...

#include<stdio.h>
#include<math.h>
int main()
{int i,n,flag;

for(n=3;n<=1000;n++)
{flag=1;       
for(i=2;i<=sqrt(n);i++)
        {
                if(n%i==0)
                        {
                        flag=0;
                        break;
                        }
        }
if(flag!=0)printf("%d\n",n);
}
}
改过之后确实可以,是我想象中的暴力算法。
虽然devc++看不出sqrt这个函数的参数有问题,但是非常感谢你。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2015-11-15 10:17:05 | 显示全部楼层

这句是依次尝试每个数是否符合条件遍历到该数的根号该数循环。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2015-11-15 10:20:51 | 显示全部楼层

谢谢前辈的热心解答,问题已经解决了,非常感谢
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2015-11-15 18:27:58 | 显示全部楼层

嗯,那个sqrt的参数最好强制转换一下类型,不是dev检查不出来,是自动给转换了,vc6也能自动转换,不过在vs上面好像都不能自动转换了,因为sqrt有三种浮点类型,编译器不知道要转换成哪个~
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2015-11-15 23:37:15 | 显示全部楼层
0xcc 发表于 2015-11-15 18:27
嗯,那个sqrt的参数最好强制转换一下类型,不是dev检查不出来,是自动给转换了,vc6也能自动转换,不过在 ...

原来如此,感谢感谢。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2015-11-20 21:08:10 | 显示全部楼层

sqrt()平方根判断,这句很好理解啊
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2015-11-20 22:27:11 | 显示全部楼层
wangzai 发表于 2015-11-20 21:08
sqrt()平方根判断,这句很好理解啊

知道是平方根,不知道为什么用平方根求素数
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2015-11-21 08:12:44 | 显示全部楼层
能不能弱弱问一句,你知道素数是什么吗
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2015-11-21 09:59:26 | 显示全部楼层
wangzai 发表于 2015-11-21 08:12
能不能弱弱问一句,你知道素数是什么吗

这算是嘲讽吗?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2015-11-24 13:32:47 | 显示全部楼层
没有没有,我只是觉得可能你素数这个概念还没弄懂
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2015-11-24 16:29:36 | 显示全部楼层
wangzai 发表于 2015-11-24 13:32
没有没有,我只是觉得可能你素数这个概念还没弄懂

我修改过后的代码忽略了2,应该从2开始。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-11-26 13:45

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表