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 求解O-S方程的特征值问题给出边界层布拉休斯平行流的中性曲线
  • ¥15 谁有desed数据集呀
  • ¥20 手写数字识别运行c仿真时,程序报错错误代码sim211-100
  • ¥15 关于#hadoop#的问题
  • ¥15 (标签-Python|关键词-socket)
  • ¥15 keil里为什么main.c定义的函数在it.c调用不了
  • ¥50 切换TabTip键盘的输入法
  • ¥15 可否在不同线程中调用封装数据库操作的类
  • ¥15 微带串馈天线阵列每个阵元宽度计算
  • ¥15 keil的map文件中Image component sizes各项意思