鱼C论坛

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

[已解决]代码求助,比较那个代码更高效

[复制链接]
发表于 2025-4-11 16:30:48 | 显示全部楼层
解答

两段代码都正确但效率差异明显,老师的代码更高效。分析如下:

step += 1 的暴力枚举方式需要遍历所有自然数:
  • 需要检查每个数字是否符合5个条件
  • 当正确解是119时,需要执行119次循环


而老师的 x = 7*i 利用了关键条件优化:
  • 直接遍历7的倍数(满足最后"刚好被7整除"的条件)
  • 每次只需检查4个余数条件
  • 当正确解是119时,只需执行17次循环(119/7=17)



  1. # 最优解法参考代码
  2. x = 7
  3. i = 1
  4. while True:
  5.     if x%2==1 and x%3==2 and x%5==4 and x%6==5:
  6.         print(f"解答:至少有{x}级台阶")
  7.         break
  8.     i += 1
  9.     x = 7 * i
复制代码


效率对比数据:
  • 鱼油代码执行119次循环,检查595次条件
  • 老师代码执行17次循环,检查68次条件


优化思路
当遇到此类问题时,应该:
1. 优先利用最严格的条件(这里是7的倍数)
2. 通过数学观察减少循环次数(如利用步长7的增量)
3. 减少每次循环的条件判断次数

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-10-30 06:45

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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