鱼C论坛

 找回密码
 立即注册
查看: 3137|回复: 4

为什么j的开方要赋给k呢,这个编程有点看不懂。求解

[复制链接]
发表于 2018-3-24 16:39:10 | 显示全部楼层 |阅读模式

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

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

x
本帖最后由 byzh168 于 2018-3-24 16:40 编辑

#include <stdio.h>
#include <math.h>

int main()
{
        long long i, j, k, l, num = 600851475143;
        _Bool flag = 1;

        for (i = 2, j = num/i; flag != 0; i++, j = num/i, flag = 1)
        {
                if (i * j == num)
                {
                        k = sqrt((double)j);
                        for (l = 2; l <= k; l++)
                        {
                                if (j % l == 0)
                                {
                                        flag = 0;
                                        break;
                                }
                        }
                        if (flag)
                        {
                                break;
                        }
                }
        }

        printf("%lld\n", j);

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

使用道具 举报

发表于 2018-3-24 17:29:52 From FishC Mobile | 显示全部楼层
因为一个数的最大素数因子不会超过其开方的值
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-3-24 17:58:41 | 显示全部楼层
BngThea 发表于 2018-3-24 17:29
因为一个数的最大素数因子不会超过其开方的值

6 = 2 * 3,但是3的平方是9啊
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-3-25 07:16:36 From FishC Mobile | 显示全部楼层
Zmynx_2017 发表于 2018-3-24 17:58
6 = 2 * 3,但是3的平方是9啊

我的描述有点问题,本意是指一个素数的判定指需要从2到其开根号即可
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-3-29 14:17:28 | 显示全部楼层
Zmynx_2017 发表于 2018-3-24 17:58
6 = 2 * 3,但是3的平方是9啊

6的开方是取证是2,对2取余就可以知道6不是素数了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-29 16:32

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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