Daly_24 2022-02-15 14:41 采纳率: 100%
浏览 20
已结题

CS61A的homework questions

问题就是求最大公因数

def largest_factor(n):
    """Return the largest factor of n that is smaller than n.
    >>> largest_factor(15) # factors are 1, 3, 5
    5
    >>> largest_factor(80) # factors are 1, 2, 4, 5, 8, 10, 16, 20, 40
    40
    >>> largest_factor(13) # factor is 1 since 13 is prime
    1
    """
    i = 1
    while i < n ** 1/2:
        i += 1
        if not n % i:
            return n//i
    return 1

这后面的循环内容没看明白,if not 是怎么用的,还有那个return n//i和return 1也不懂,能给讲讲吗

  • 写回答

2条回答 默认 最新

  • 谛凌 2022-02-15 14:44
    关注
    • if not 就是后面如果是0或者False 条件成立
    • return 1是因为两个数没有大于1的公因数,因此最大公因数只能是1
    • if not n%i表示n对i取余为0时,not 0就是1了,所以条件成立,表示找到了公因数,return n//i是保留n//i的整数部分
    • /得到的是浮点数,//得到的是结果的整数部分
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 2月23日
  • 已采纳回答 2月15日
  • 创建了问题 2月15日

悬赏问题

  • ¥15 求帮我调试一下freefem代码
  • ¥15 matlab代码解决,怎么运行
  • ¥15 R语言Rstudio突然无法启动
  • ¥15 关于#matlab#的问题:提取2个图像的变量作为另外一个图像像元的移动量,计算新的位置创建新的图像并提取第二个图像的变量到新的图像
  • ¥15 改算法,照着压缩包里边,参考其他代码封装的格式 写到main函数里
  • ¥15 用windows做服务的同志有吗
  • ¥60 求一个简单的网页(标签-安全|关键词-上传)
  • ¥35 lstm时间序列共享单车预测,loss值优化,参数优化算法
  • ¥15 Python中的request,如何使用ssr节点,通过代理requests网页。本人在泰国,需要用大陆ip才能玩网页游戏,合法合规。
  • ¥100 为什么这个恒流源电路不能恒流?