久远的心宿三 发表于 2020-10-2 19:04:14

大佬们,我这个程序该怎么修改啊?

def bin1(i):
    list1 = []
    if i < 1:
      list1.reverse()
      str1 = ''.join(str(n) for n in list1)
      return str1
    else:
      list1.append(i%2)
      bin1(i//2)
c = int(input('请输入要转换的数字:'))
print(bin1(c))


def bin1(i):
    if i < 1:
      list1.reverse()
      str1 = ''.join(str(n) for n in list1)
      return str1
    else:
      list1.append(i%2)
      bin1(i//2)
list1 = []
c = int(input('请输入要转换的数字:'))
print(bin1(c))

用递归写十进制转化为二进制,用我的这个思路,就是首先创建一个空列表,然后每运行一次函数就往列表里加一个数,最后将列表反转后转化为字符串输出。。现在问题是这个空列表该怎么创建啊???这个list1 = []不管放在第一个位置还是第二个位置,程序运行后都返回的是none。。请问大佬们该怎那么修改呢??

久远的心宿三 发表于 2020-10-2 19:06:47

我的理解是第一个程序的问题应该是每一次运行函数,都会将list1重置成空的,第二个的问题是list1是全局变量,不能被函数修改。。。
但就算直到问题,我也不会修改,求大神解救!!

zltzlt 发表于 2020-10-2 19:08:21

不是已经在上个问题回答你了吗?

疾风怪盗 发表于 2020-10-2 19:18:06

这样就对了,放在函数里,每次递归都重置了
def bin1(list1,i):
    if i < 1:
      list1.reverse()
    else:
      list1.append(i%2)
      bin1(list1,i//2)
    str1 = ''.join(str(n) for n in list1)
    return str1
#c = int(input('请输入要转换的数字:'))
c=55
list1=[]
print(bin1(list1,c))

sbx 发表于 2020-10-2 20:38:47

我来看看!
页: [1]
查看完整版本: 大佬们,我这个程序该怎么修改啊?