大佬们,我这个程序该怎么修改啊?
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。。请问大佬们该怎那么修改呢?? 我的理解是第一个程序的问题应该是每一次运行函数,都会将list1重置成空的,第二个的问题是list1是全局变量,不能被函数修改。。。
但就算直到问题,我也不会修改,求大神解救!! 不是已经在上个问题回答你了吗? 这样就对了,放在函数里,每次递归都重置了
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))
我来看看!
页:
[1]