鱼C论坛

 找回密码
 立即注册
查看: 2432|回复: 2

素数的问题

[复制链接]
发表于 2016-7-14 18:03:41 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
#include <stdio.h>

int main()
{
        int i, num;
        _Bool flag = 1;

        printf("请输入一个整数:");
        scanf("%d", &num);

        for (i = 2; i < num / 2; i++)         请问这里的 i < num / 2 是什么意思??? 求解答
        {
                if (num % i == 0)
                {
                        flag = 0;
                }
        }

        if (flag)
        {
                printf("%d是一个素数!\n", num);
        }
        else
        {
                printf("%d不是一个素数!\n", num);
        }

        return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2016-7-14 23:53:35 | 显示全部楼层
...
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2016-7-15 09:31:25 | 显示全部楼层
<友情提示:楼主,循环过程的条件,有点问题,自己尝试输入4即可了解>

判断10是不是素数,可以判断到10/2 也就是5 就可以了。
因为你从2开始的,如果能被2整除,证明不是素数,6 7 8 9 这些数也就不用判断了
如果不能被2整除,那也不用判断了,因为需要判断的数字的一半(例如5)以上的数字,乘数不可能是整数了(除了数字本身),你看,6 * ? = 10  ---- 6都不可能是整数了,更何况更大的呢?

并且,我们一般用 sqrt 这个函数,不是使用数字的中间值,而是使用它的平方根。想一想为什么?

(提示:比如6, 2*3 和 3*2 有区别吗?)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-1-20 05:59

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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