鱼C论坛

 找回密码
 立即注册
查看: 1238|回复: 16

[已解决]c语言第一阶段考核第二题

[复制链接]
发表于 2020-8-12 16:13:08 | 显示全部楼层 |阅读模式
2鱼币
YV0R0$_TU2D8EXNXR35~X[4.png    这个是什么算法吗,可以解释一下这个算法吗,求解j的目的是什么
#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", i);

        return 0;
}
最佳答案
2020-8-12 16:13:09
题目只需要找到最大的质数因子,j就是我们要找的数,对于i不用去管

最佳答案

查看完整内容

题目只需要找到最大的质数因子,j就是我们要找的数,对于i不用去管
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-8-12 16:13:09 | 显示全部楼层    本楼为最佳答案   
题目只需要找到最大的质数因子,j就是我们要找的数,对于i不用去管
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-8-12 16:18:20 | 显示全部楼层
i*j==num,就说明j是num的因子数,然后就对j进行判断是否是素数
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-8-12 16:26:25 | 显示全部楼层
这一部分是判断是不是质数,也就是素数
  1. k = sqrt((double)j);
  2.                         for (l = 2; l <= k; l++)
  3.                         {
  4.                                 if (j % l == 0)
  5.                                 {
  6.                                         flag = 0;
  7.                                         break;
  8.                                 }
  9.                         }
  10.                         if (flag)
  11.                         {
  12.                                 break;
  13.                         }
  14.                 }
复制代码

这一段主要是判断j是不是num的因子
  1. for (i = 2, j = num/i; flag != 0; i++, j = num/i, flag = 1)
  2.         {
  3.                 if (i * j == num)
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2020-8-12 16:26:27 | 显示全部楼层
本帖最后由 大学里的小菜鸡 于 2020-8-12 16:31 编辑
baige 发表于 2020-8-12 16:18
i*j==num,就说明j是num的因子数,然后就对j进行判断是否是素数


那为什么输出的是i而不是j呢
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2020-8-12 16:30:27 | 显示全部楼层
baige 发表于 2020-8-12 16:26
这一部分是判断是不是质数,也就是素数

这一段主要是判断j是不是num的因子

判断素数和因子懂了,但是不懂输出的为什么是i而不是j
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2020-8-12 16:33:21 | 显示全部楼层
大学里的小菜鸡 发表于 2020-8-12 16:26
那为什么输出的是i而不是j呢

它是怎么判断得知i要比j大的
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-8-12 16:39:14 | 显示全部楼层
大学里的小菜鸡 发表于 2020-8-12 16:33
它是怎么判断得知i要比j大的

答案写错了,应该是j,刚写了个程序判断答案的i不是素数
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-8-12 16:40:41 | 显示全部楼层
87625999/71 = 1 234 169
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-8-12 16:41:48 | 显示全部楼层
问题解决的话,就结贴吧
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2020-8-12 16:42:51 | 显示全部楼层
baige 发表于 2020-8-12 16:39
答案写错了,应该是j,刚写了个程序判断答案的i不是素数

输出的确实是i比j大,但是是怎么判断的
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2020-8-12 16:44:42 | 显示全部楼层
本帖最后由 大学里的小菜鸡 于 2020-8-12 16:48 编辑
baige 发表于 2020-8-12 16:39
答案写错了,应该是j,刚写了个程序判断答案的i不是素数


还有他判断了j是质数,i就不用判断是不是质数了吗,还是说这个数比较特殊,确定一个因子是质数了另一个因子就是质数了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-8-12 16:44:42 | 显示全部楼层
大学里的小菜鸡 发表于 2020-8-12 16:42
输出的确实是i比j大,但是是怎么判断的

怎么判断什么?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2020-8-12 16:46:05 | 显示全部楼层
baige 发表于 2020-8-12 16:44
怎么判断什么?

判断i比j大,程序中没有i与j的大小的判断,直接输出i,不用进行i和j的判断吗
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-8-12 16:50:09 | 显示全部楼层
大学里的小菜鸡 发表于 2020-8-12 16:46
判断i比j大,程序中没有i与j的大小的判断,直接输出i,不用进行i和j的判断吗

不需要,答案就是j, i是小甲鱼打错了而已,
当满足第一个j既是num的因数,又是素数的时候,循环就退出了,此时的j一定是num的最大质数因子,不需要去判断i,j,的大小
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2020-8-12 16:51:23 | 显示全部楼层
baige 发表于 2020-8-12 16:50
不需要,答案就是j, i是小甲鱼打错了而已,
当满足第一个j既是num的因数,又是素数的时候,循环就退出了 ...


不是啊,你输出i和j看看,i的值要比j的值大,j=6857  i=87625999
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-8-12 16:54:47 | 显示全部楼层
大学里的小菜鸡 发表于 2020-8-12 16:51
不是啊,你输出i和j看看,i的值要比j的值大,j=6857  i=87625999

i一直在累加,如果一直没有符合的情况,i最后一定会比j大很多的,
并且i不是素数,你可以去求一下,我上面已经写了,i可以被71整除
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-5-2 15:57

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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