很简单的一段,当练手
def s2e(): e = [0,0,0,0,0,0,0,0] s = int(input("请输入一个十位数:")) for i in range(0,8,1): e[i] = int(s%2) s=s//2 e.reverse() print("二进制数为:",e) def e2s(): s=[0,0,0,0,0,0,0,0] a=0 s=list(input("请输入一个二进制数:")) s.reverse() for i in range(0,len(s),1): if int(s[i]) == 1: a+=pow(2,i) print("十进制数是:",a) while 1: choose = int(input("二进制转十进制请输入1\n十进制转二进制请输入2\n")) if choose==1: e2s() elif choose==2: s2e() else: break
二进制输出为数组形式
还有待完善
欢迎大家提建议
思路:
二进制转十进制:
我这里用的是八位二进制,从右到左,第一位是2的0次方,第二位是2的1次方,以此类推,第8位便是2的7次方,所以只要判断位数上的数字是1还是0,因为是从右到左,所以先把数组倒过来,这样数组下标就好算一点,例如00000101(数字小好算点,嘿嘿);倒过来后便是10100000,此时第0位为1,那么便是2的0次方,第2位是1,便是2的2次方,所有相加,就得到了十进制数
十进制转二进制:
附上一张百度来的图
每次除以2求余,再用余数除以2再求余,如此直到最后一个数为1,再如图,逆序排列,此时的逆序排列的数便是二进制数。
原文地址:https://www.cnblogs.com/helex/p/10061708.html
时间: 2024-10-28 14:03:31