鱼C论坛

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

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

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

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

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

x


第一题我这样写的
  1. def gcd(x=1,y=1):
  2.     #gcd(x,y)函数即求x,y的最大公约数
  3.     if x > y:
  4.         a=x
  5.         b=y
  6.     else:
  7.         a=y
  8.         b=x
  9.     while a % b != 0:
  10.         a = b
  11.         b = a % b
  12.     return b
复制代码
第二题及测试是这样写的
  1. >>> def ttt(x):
  2.         b=list()
  3.         if x == 0:
  4.                 return 0
  5.         else:
  6.                 while x / 2 >=1:
  7.                         b.append(x%2)
  8.                         b.append(1)
  9.         return b.reverse()

  10. >>> ttt(1)
  11. >>> ttt(0)
  12. 0
  13. >>> ttt(8)
  14. Traceback (most recent call last):
  15.   File "<pyshell#11>", line 1, in <module>
  16.     ttt(8)
  17.   File "<pyshell#8>", line 8, in ttt
  18.     b.append(1)
  19. MemoryError
复制代码
一二题都有Traceback (most recent call last):这个问题,不知道哪里粗了问题



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


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

循环条件我也改了下,参考代码如下:

  1. def gcd(x=1,y=1):
  2.     #gcd(x,y)函数即求x,y的最大公约数
  3.     if x > y:
  4.         a=x
  5.         b=y
  6.     else:
  7.         a=y
  8.         b=x
  9.     while b != 0:
  10.         c = a % b
  11.         a = b
  12.         b = c
  13.     return a
复制代码


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

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

参考代码:
  1. def ttt(x):
  2.     b = list()
  3.     if x == 0:
  4.         return 0
  5.     else:
  6.         while x:
  7.             b.append(x % 2)
  8.             x = x // 2
  9.         b.reverse()
  10.     return b
复制代码


如果需要打印出完整的字符串,可以用 join 拼接下,这里的 0b 就表示这里的数字是二进制的意思:

  1. def ttt(x):
  2.     b = list()
  3.     if x == 0:
  4.         return 0
  5.     else:
  6.         while x:
  7.             b.append(str(x % 2))
  8.             x = x // 2
  9.         b.reverse()
  10.     return '0b'+''.join(b)
复制代码

小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

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


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

循环条件我也改了下,参考代码如下:

  1. def gcd(x=1,y=1):
  2.     #gcd(x,y)函数即求x,y的最大公约数
  3.     if x > y:
  4.         a=x
  5.         b=y
  6.     else:
  7.         a=y
  8.         b=x
  9.     while b != 0:
  10.         c = a % b
  11.         a = b
  12.         b = c
  13.     return a
复制代码


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

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

参考代码:
  1. def ttt(x):
  2.     b = list()
  3.     if x == 0:
  4.         return 0
  5.     else:
  6.         while x:
  7.             b.append(x % 2)
  8.             x = x // 2
  9.         b.reverse()
  10.     return b
复制代码


如果需要打印出完整的字符串,可以用 join 拼接下,这里的 0b 就表示这里的数字是二进制的意思:

  1. def ttt(x):
  2.     b = list()
  3.     if x == 0:
  4.         return 0
  5.     else:
  6.         while x:
  7.             b.append(str(x % 2))
  8.             x = x // 2
  9.         b.reverse()
  10.     return '0b'+''.join(b)
复制代码

小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-8-18 18:19:11 | 显示全部楼层
楼上说的对
小甲鱼最新课程 -> https://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)可以吗?
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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



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

join 可以直接将列表中的字符串全部拼接在一起
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

join 可 ...

感谢
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-7-1 09:49

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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