大家好,又见面了,我是你们的朋友全栈君。
二进制数转换成十进制数:二进制数从右向左每位数乘以2的次方(从0开始,从右向左依次 1),然后相加求和即可
如:0101转成十进制为:1*20 0*21 1*22 0*23 =1 0 4 0=5
算法实现:
#coding=utf-8 b=raw_input(“请输入一个二进制数:”.decode(“utf-8”).encode(“gbk”)) sum=0 for i in range(len(b)): sum =int(b[len(b)-1-i])*pow(2,i) print u”转换成十进制数是:”,sum
——————————————-
十进制数转换成二进制数:十进制数除2取余,商继续除2取余,直到商为0,所有余数逆顺即可
如:12转换成二进制是:1100
12/2=6 —— 0 第4位
6/2=3 —— 0 第3位
3/2=1 —— 1 第2位
1/2=0 —— 1 第1位
算法实现:
#coding=utf-8 n=int(raw_input(u”请输入一个正整数:”.encode(“gbk”))) res=[] res.append(str(n%2)) while n/2!=0: n=n/2 res.append(str(n%2)) res.reverse() print u”转化为二进制是:”,””.join(res)
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/155913.html原文链接:https://javaforall.cn