鱼C论坛

 找回密码
 立即注册
查看: 3326|回复: 10

程序编译未报错,数字小可正常执行,数字大hang住

[复制链接]
发表于 2019-11-13 17:42:08 | 显示全部楼层 |阅读模式

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

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

x
求解一个问题:[阶段考核] 第一阶段考核(考核S1E1~S1E16知识点)第二题

以下是我的代码,当数字小时执行无误,当按题目给的数字执行时,会hang住,不知道是什么原因?


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

  3. //#define NUM 600851475143

  4. int main()
  5. {
  6.         long long i,max=0,j,NUM = 600851475143;
  7.         _Bool value;
  8.         for (i=2;i<NUM/2;i++)
  9.         {
  10.                 if (NUM % i == 0)
  11.                 {
  12.                         for (j=2;j<=sqrt((double)i);j++)
  13.                         {
  14.                                 if (i % j == 0)
  15.                                 {
  16.                                         value = 0;
  17.                                         break;
  18.                                 }
  19.                                 else
  20.                                         value = 1;
  21.                         }
  22.                         if (value)
  23.                         {
  24.                                 max = max > i ? max : i;
  25.                         }
  26.                 }
  27.         }
  28.       
  29.         printf("max prime factor = %lld\n",max);
  30.       
  31.       
  32.         return 0;
  33. }
复制代码



strace查看

strace查看

--- SIGWINCH {si_signo=SIGWINCH, si_code=SI_KERNEL} ---

小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2019-11-13 18:17:10 | 显示全部楼层

回帖奖励 +10 鱼币

     楼主,你应该交代一下,这道题要干啥?
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

 楼主| 发表于 2019-11-14 10:49:24 | 显示全部楼层
2. 编写一个程序,求解 600851475143 的最大质数因子是多少?
每个合数都可以写成几个质数(素数)相乘的形式,这几个质数就都叫做这个合数的质数因子。
比如 13195 的质数因子有 5, 7, 13 和 29。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2019-11-14 10:52:11 | 显示全部楼层
jackz007 发表于 2019-11-13 18:17
楼主,你应该交代一下,这道题要干啥?

谢谢提醒~
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-11-16 09:39:54 | 显示全部楼层

回帖奖励 +10 鱼币

代码写的挺好的,看不出有什么错误!
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-11-24 10:45:28 | 显示全部楼层

回帖奖励 +10 鱼币

循环中的循环
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-11-24 13:31:22 | 显示全部楼层

回帖奖励 +10 鱼币

我看的时候就是一脸懵逼
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-11-24 14:18:47 | 显示全部楼层

回帖奖励 +10 鱼币

本帖最后由 Croper 于 2019-11-24 14:42 编辑

楼主你这时间复杂度是O[N^3/2],太高了啊。
自己算一算,N=600851475143时你需要循环164666670424947200次;
如果每次循环需要0.1微秒,那么计算需要耗时16466667042秒,
合190586天,大概是522年。

等你算出来三体舰队已经到地球了。。
所以你还是优化下你的算法吧,

评分

参与人数 1荣誉 +5 鱼币 +5 贡献 +3 收起 理由
人造人 + 5 + 5 + 3 鱼C有你更精彩^_^

查看全部评分

小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-11-24 14:26:21 From FishC Mobile | 显示全部楼层
Croper 发表于 2019-11-24 14:18
楼主你这时间复杂度是O[N^3/2],太高了啊。
自己算一算,N=600851475143时你需要循环164666670424947200次 ...

子子孙孙无穷匮焉,总有算出的一天>_<
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2019-11-30 15:15:52 | 显示全部楼层
Croper 发表于 2019-11-24 14:18
楼主你这时间复杂度是O[N^3/2],太高了啊。
自己算一算,N=600851475143时你需要循环164666670424947200次 ...

已经优化了,前几天没看, 谢谢噢~
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2019-11-30 15:23:16 | 显示全部楼层
另外这一题,小甲鱼的答案不对,87625999不是质数,正确答案应该是6857
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-7-12 21:43

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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