鱼C论坛

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

[已解决]课后作业求助

[复制链接]
发表于 前天 17:27 | 显示全部楼层 |阅读模式

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

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

x
>>> def isPowerOfTwo(n):

...     if n > 0:

...         if n == 1:

...             return True

...         if n % 2 == 1:

...             return False

...         return isPowerOfTwo(n/2)

...     else:

...         return False

...        

>>> isPowerOfTwo(1)

True

>>> isPowerOfTwo(0)

False

>>> isPowerOfTwo(8)

True
这道题小甲鱼说解析:if n % 2 == 1 这句虽然不要也可以,但是有它可以极大地提高代码的工作效率。
但是如果没有这一项,isPowerOfTwo(9),再到isPowerOfTwo(4.5),它会陷入无限循环中,就错了。
>>> isPowerOfTwo(9)
Traceback (most recent call last):
  File "<pyshell#38>", line 1, in <module>
    isPowerOfTwo(9)
  File "<pyshell#35>", line 7, in isPowerOfTwo
    return isPowerOfTwo(n/2)
  File "<pyshell#35>", line 7, in isPowerOfTwo
    return isPowerOfTwo(n/2)
  File "<pyshell#35>", line 7, in isPowerOfTwo
    return isPowerOfTwo(n/2)
  [Previous line repeated 1023 more times]
RecursionError: maximum recursion depth exceeded
最佳答案
前天 20:33
如果移除 `if n % 2 == 1` 条件,当你调用 `isPowerOfTwo(9)` 时,代码会计算 `isPowerOfTwo(4.5)`,然后 `isPowerOfTwo(2.25)`,如此继续下去,`n` 会陷入在两个小于1的数字之间无限递归,导致 `RecursionError`。

就像Al说的这样
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 前天 17:27 | 显示全部楼层
小甲鱼的解析是正确的,代码中的 `if n % 2 == 1` 确实可以提高效率,并防止程序进入无限递归从而导致递归深度超限。以下是对代码的解释:

1. **基本逻辑**: 该函数用来判断一个数是否是2的幂。
   
2. **递归调用**: `isPowerOfTwo(n/2)` 会不断将 `n` 除以2,再递归调用函数本身。

3. **关键条件**:
   - `n == 1`: 确保当 `n` 正好是2的某次幂时,返回 `True`。
   - `n % 2 == 1`: 确保如果 `n` 无法被2整除(即 `n` 是奇数并且大于1),直接返回 `False`,避免无用的递归。

4. **问题说明**: 如果移除 `if n % 2 == 1` 条件,当你调用 `isPowerOfTwo(9)` 时,代码会计算 `isPowerOfTwo(4.5)`,然后 `isPowerOfTwo(2.25)`,如此继续下去,`n` 会陷入在两个小于1的数字之间无限递归,导致 `RecursionError`。

因此,`if n % 2 == 1` 的判断是必要的,它们可以避免对小数进行不必要的递归调用,从而使程序更高效和安全。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 前天 18:43 | 显示全部楼层
第几课
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 前天 18:47 | 显示全部楼层
我找到了,应该是甲鱼老湿说错了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 前天 20:32 | 显示全部楼层
某一个“天” 发表于 2025-1-8 18:47
我找到了,应该是甲鱼老湿说错了

第五十讲的第一题,那俺的理解没有问题?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 前天 20:32 | 显示全部楼层
cindyber 发表于 2025-1-8 20:32
第五十讲的第一题,那俺的理解没有问题?

你理解没问题,不能删
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 前天 20:33 | 显示全部楼层    本楼为最佳答案   
如果移除 `if n % 2 == 1` 条件,当你调用 `isPowerOfTwo(9)` 时,代码会计算 `isPowerOfTwo(4.5)`,然后 `isPowerOfTwo(2.25)`,如此继续下去,`n` 会陷入在两个小于1的数字之间无限递归,导致 `RecursionError`。

就像Al说的这样
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-1-10 05:36

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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