鱼C论坛

 找回密码
 立即注册
查看: 1977|回复: 5

[已解决]17讲的第1、2题

[复制链接]
发表于 2020-8-18 17:42:46 | 显示全部楼层 |阅读模式

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

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

x


第一题我这样写的
def gcd(x=1,y=1):
    #gcd(x,y)函数即求x,y的最大公约数
    if x > y:
        a=x
        b=y
    else:
        a=y
        b=x
    while a % b != 0:
        a = b
        b = a % b
    return b
第二题及测试是这样写的
>>> def ttt(x):
        b=list()
        if x == 0:
                return 0
        else:
                while x / 2 >=1:
                        b.append(x%2)
                        b.append(1)
        return b.reverse()

>>> ttt(1)
>>> ttt(0)
0
>>> ttt(8)
Traceback (most recent call last):
  File "<pyshell#11>", line 1, in <module>
    ttt(8)
  File "<pyshell#8>", line 8, in ttt
    b.append(1)
MemoryError
一二题都有Traceback (most recent call last):这个问题,不知道哪里粗了问题



最佳答案
2020-8-18 17:59:35
本帖最后由 Twilight6 于 2020-8-18 18:01 编辑


第一题,代码逻辑也有错误,你应该先除后求余,而你直接相等 然后 求余 肯定等于 0 的啊

循环条件我也改了下,参考代码如下:
def gcd(x=1,y=1):
    #gcd(x,y)函数即求x,y的最大公约数
    if x > y:
        a=x
        b=y
    else:
        a=y
        b=x
    while b != 0:
        c = a % b
        a = b
        b = c
    return a

第二题,你 x % 2 之后就是余数了,不用你在加个 1 进到列表中去

而且列表的绝大多数方法没有返回值,所以你直接返回 b.reverse() 永远都是 None的

参考代码:
def ttt(x):
    b = list()
    if x == 0:
        return 0
    else:
        while x:
            b.append(x % 2)
            x = x // 2
        b.reverse()
    return b

如果需要打印出完整的字符串,可以用 join 拼接下,这里的 0b 就表示这里的数字是二进制的意思:
def ttt(x):
    b = list()
    if x == 0:
        return 0
    else:
        while x:
            b.append(str(x % 2))
            x = x // 2
        b.reverse()
    return '0b'+''.join(b)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-8-18 17:59:35 | 显示全部楼层    本楼为最佳答案   
本帖最后由 Twilight6 于 2020-8-18 18:01 编辑


第一题,代码逻辑也有错误,你应该先除后求余,而你直接相等 然后 求余 肯定等于 0 的啊

循环条件我也改了下,参考代码如下:
def gcd(x=1,y=1):
    #gcd(x,y)函数即求x,y的最大公约数
    if x > y:
        a=x
        b=y
    else:
        a=y
        b=x
    while b != 0:
        c = a % b
        a = b
        b = c
    return a

第二题,你 x % 2 之后就是余数了,不用你在加个 1 进到列表中去

而且列表的绝大多数方法没有返回值,所以你直接返回 b.reverse() 永远都是 None的

参考代码:
def ttt(x):
    b = list()
    if x == 0:
        return 0
    else:
        while x:
            b.append(x % 2)
            x = x // 2
        b.reverse()
    return b

如果需要打印出完整的字符串,可以用 join 拼接下,这里的 0b 就表示这里的数字是二进制的意思:
def ttt(x):
    b = list()
    if x == 0:
        return 0
    else:
        while x:
            b.append(str(x % 2))
            x = x // 2
        b.reverse()
    return '0b'+''.join(b)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-8-18 18:19:11 | 显示全部楼层
楼上说的对
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-8-18 19:15:02 | 显示全部楼层
本帖最后由 Arcticfoxer 于 2020-8-18 19:16 编辑
Twilight6 发表于 2020-8-18 17:59
第一题,代码逻辑也有错误,你应该先除后求余,而你直接相等 然后 求余 肯定等于 0 的啊

循环条件我也 ...




第二题如果不标0b,直接return str(b)可以吗?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-8-18 20:19:21 | 显示全部楼层
Arcticfoxer 发表于 2020-8-18 19:15
第二题如果不标0b,直接return str(b)可以吗?



可以直接 return ''.join(b) ,或者像小甲鱼的课后答案 用 while 循环依次进行拼接后返回

join 可以直接将列表中的字符串全部拼接在一起
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-8-19 22:48:38 | 显示全部楼层
Twilight6 发表于 2020-8-18 20:19
可以直接 return ''.join(b) ,或者像小甲鱼的课后答案 用 while 循环依次进行拼接后返回

join 可 ...

感谢
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-1-11 05:51

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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