|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
- 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。。请问大佬们该怎那么修改呢??
这样就对了,放在函数里,每次递归都重置了
- 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))
复制代码
|
|