鱼C论坛

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

[已解决]课后23,24,

[复制链接]
发表于 2021-10-9 22:55:02 | 显示全部楼层 |阅读模式

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

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

x
def hanshu(x):
    list1=[]
    if x:
        list1.append(x%2)
        x = x//2
        return hanshu(x)
    list2=list(reversed(list1))
    print(str(list2))

x = int(input('请输入:'))
print(hanshu(x))

为什么结果是[]
最佳答案
2021-10-10 14:25:58
名字是啥 发表于 2021-10-10 14:10
不好意思,是我没解释清楚,这个是十进制转二进制的函数


这是我以前编写的代码,希望对你有帮助
class NumeralSystem:
    def __init__(self, num):
        self.num = num
    
    def binary(self): # 二进制
        res = []
        n = self.num
        while n > 1:
            n, b = divmod(n, 2)
            res.append(str(b))
        res.append(str(n))
        return '0b'+''.join(res[::-1])
    
    def octal(self): # 八进制
        res = []
        n = self.num
        while n > 7:
            n, b = divmod(n, 8)
            res.append(str(b))
        res.append(str(n))
        return '0o'+''.join(res[::-1])
    
    def hexadecimal(self): # 十六进制
        Hex = {10: 'A', 11: 'B', 12: 'C', 13: 'D', 14: 'E', 15: 'F'}
        res = []
        n = self.num
        while n > 15:
            n, b = divmod(n, 16)
            if b > 9: res.append(Hex[b])
            else: res.append(str(b))
        if n > 9: res.append(Hex[n])
        else: res.append(str(n))
        return '0x'+''.join(res[::-1])

num = NumeralSystem(796)
print(num.binary())
print(num.octal())
print(num.hexadecimal())
0b1100011100
0o1434
0x31C
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2021-10-9 23:01:41 | 显示全部楼层

def hanshu(x):
    list1=[]
    if x:
        list1.append(x%2)
        x = x//2
        return hanshu(x)
    list2=list(reversed(list1))
    print(str(list2))

x = int(input('请输入:'))
print(hanshu(x))

我猜的:红色部分改成list1,不知道是不是你想要的东西
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-10-10 09:19:42 | 显示全部楼层
希望我的代码对你有帮助
def function(x, arr = None): # 这里多带一个参数,用于输出最终答案
    if not x: # 设定退出递归条件,并返回最终数据
        return arr
    elif not arr:
        arr = list() # 创建新列表储存递归数据
    arr.append(x) # 每当递归一次,进行储存
    x //= 2
    return function(x, arr) # 递归(并携带最新参数 arr)

x = int(input('请输入:'))
print(function(x))
请输入:15
[15, 7, 3, 1]

请输入:22
[22, 11, 5, 2, 1]
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-10-10 14:10:51 | 显示全部楼层
傻眼貓咪 发表于 2021-10-10 09:19
希望我的代码对你有帮助

不好意思,是我没解释清楚,这个是十进制转二进制的函数
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-10-10 14:25:58 | 显示全部楼层    本楼为最佳答案   
名字是啥 发表于 2021-10-10 14:10
不好意思,是我没解释清楚,这个是十进制转二进制的函数


这是我以前编写的代码,希望对你有帮助
class NumeralSystem:
    def __init__(self, num):
        self.num = num
    
    def binary(self): # 二进制
        res = []
        n = self.num
        while n > 1:
            n, b = divmod(n, 2)
            res.append(str(b))
        res.append(str(n))
        return '0b'+''.join(res[::-1])
    
    def octal(self): # 八进制
        res = []
        n = self.num
        while n > 7:
            n, b = divmod(n, 8)
            res.append(str(b))
        res.append(str(n))
        return '0o'+''.join(res[::-1])
    
    def hexadecimal(self): # 十六进制
        Hex = {10: 'A', 11: 'B', 12: 'C', 13: 'D', 14: 'E', 15: 'F'}
        res = []
        n = self.num
        while n > 15:
            n, b = divmod(n, 16)
            if b > 9: res.append(Hex[b])
            else: res.append(str(b))
        if n > 9: res.append(Hex[n])
        else: res.append(str(n))
        return '0x'+''.join(res[::-1])

num = NumeralSystem(796)
print(num.binary())
print(num.octal())
print(num.hexadecimal())
0b1100011100
0o1434
0x31C
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-10-10 21:37:47 | 显示全部楼层
傻眼貓咪 发表于 2021-10-10 14:25
这是我以前编写的代码,希望对你有帮助

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-1-2 00:16

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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