鱼C论坛

 找回密码
 立即注册
查看: 1535|回复: 6

[已解决]阶段考核的问题

[复制链接]
发表于 2017-7-27 21:57:48 | 显示全部楼层 |阅读模式

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

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

x
求解600851475143的最大质因数的那道题
小甲鱼老师的代码中
  1. for (l = 2; l <= k; l++)  
  2.                 {
  3.                     if (j % l == 0)   
  4.                     {
  5.                         flag = 0;   
  6.                         break;
  7.                     }
  8.                 }
  9.                
  10.                 if (flag)           
  11.                 {
  12.                         break;
  13.                 }
复制代码

这一段的作用应该是判断j是不是质数,如果是质数就跳出最外层的循环,然后输出j,那么如何能确定输出的j就是最大质因数呢
最佳答案
2017-7-27 23:00:53
1762075716 发表于 2017-7-27 22:42
原题是要求最大质数因子的

这个程序其实是从后往前找因数的,所以第一个找到的就是最大的
你看程序,i虽然是从小到大,但输出的是j,其中 i*j=num  所以,最小的i对应着最大的j
找到第一个符合要求的i,结束循环,将j输出 即为所求
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2017-7-27 22:11:35 | 显示全部楼层
就这点代码实在很难给你解释哟
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2017-7-27 22:37:08 | 显示全部楼层
ba21 发表于 2017-7-27 22:11
就这点代码实在很难给你解释哟

这是全部代码
  1. #include <stdio.h>
  2. #include <math.h>

  3. int main()
  4. {
  5.     long long i, j, k, l, num = 600851475143;
  6.     _Bool flag = 1;

  7.     for (i = 2, j = num/i; flag != 0; i++, j = num/i, flag = 1)   
  8.     {
  9.             if (i * j == num)      
  10.             {
  11.                 k = sqrt((double)j);
  12.                
  13.                 for (l = 2; l <= k; l++)  
  14.                 {
  15.                     if (j % l == 0)   
  16.                     {
  17.                         flag = 0;   
  18.                         break;
  19.                     }
  20.                 }
  21.                
  22.                 if (flag)         
  23.                 {
  24.                         break;
  25.                 }
  26.             }
  27.     }

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

  29.         return 0;
  30. }
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-7-27 22:39:10 | 显示全部楼层
已经是质因数了,还有最大一说么?
(不知道是不是我理解错了)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2017-7-27 22:42:38 | 显示全部楼层
shuofxz 发表于 2017-7-27 22:39
已经是质因数了,还有最大一说么?
(不知道是不是我理解错了)

原题是要求最大质数因子的
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-7-27 23:00:53 | 显示全部楼层    本楼为最佳答案   
1762075716 发表于 2017-7-27 22:42
原题是要求最大质数因子的

这个程序其实是从后往前找因数的,所以第一个找到的就是最大的
你看程序,i虽然是从小到大,但输出的是j,其中 i*j=num  所以,最小的i对应着最大的j
找到第一个符合要求的i,结束循环,将j输出 即为所求
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2017-7-27 23:05:34 | 显示全部楼层
shuofxz 发表于 2017-7-27 23:00
这个程序其实是从后往前找因数的,所以第一个找到的就是最大的
你看程序,i虽然是从小到大,但输出的是j ...

原来如此,我可能需要治治眼睛了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-4-19 16:10

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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