用python写十进制与二进制之间转换

很简单的一段,当练手

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

用python写十进制与二进制之间转换的相关文章

Python实现十进制和二进制之间相互转换

十进制转二进制 原理:采用除2取余,逆序排列输出. 实现:用2整除十进制整数,可以得到一个商和余数:再用2去除商,又会得到一个商和余数,如此进行,直到商为小于1时为止,然后依次翻转排序即可得到二进制数,在Python中我们采”//”(地板除)的方法实现转换 # 十进制整数转二进制def decToBin(num):    arry = []   #定义一个空数组,用于存放2整除后的商    while True:        arry.append(str(num % 2))  #用列表的ap

二进制、八进制、十进制、十六进制之间转换

一. 十进制与二进制之间的转换 (1) 十进制转换为二进制,分为整数部分和小数部分 ① 整数部分 方法:除2取余法,即每次将整数部分除以2,余数为该位权上的数,而商继续除以2,余数又为上一个位权上的数,这个步骤一直持续下去,直到商为0为止,最后读数时候,从最后一个余数读起,一直到最前面的一个余数.下面举例: 例:将十进制的168转换为二进制 得出结果 将十进制的168转换为二进制,(10101000)2 分析:第一步,将168除以2,商84,余数为0. 第二步,将商84除以2,商42余数为0.

《转载》二进制、八进制、十进制、十六进制之间转换

一. 十进制与二进制之间的转换 (1) 十进制转换为二进制,分为整数部分和小数部分 ① 整数部分 方法:除2取余法,即每次将整数部分除以2,余数为该位权上的数,而商继续除以2,余数又为上一个位权上的数,这个步骤一直持续下去,直到商为0为止,最后读数时候,从最后一个余数读起,一直到最前面的一个余数.下面举例: 例:将十进制的168转换为二进制 得出结果 将十进制的168转换为二进制,(10101000)2 分析:第一步,将168除以2,商84,余数为0. 第二步,将商84除以2,商42余数为0.

三行代码写十进制转二进制

同学c++补考,找我帮忙写十进制转二进制的代码,为了让这同学能记住,所以就想写的简单些,然后没想到居然能这么简单,感觉还不错.直接上代码: void DtoB(int d) { if(d/2) DtoB(d/2); cout<<d%2; } 考虑到有人很懒,喜欢复制就能用的代码,所以下面贴一个带主函数的完整代码好了: #include<iostream> using namespace std; void DtoB(int d) { if(d/2) DtoB(d/2); cout&

十进制与二进制之间的自由转换

#include <stdio.h>#include<stdlib.h>int main(){    int Type,a,b[10],i=0,c=0;    printf("请输入转换类型 1:十进制转二进制:2:二进制转十进制;\n");    scanf("%d",&Type);    printf("请输入原数据\n");    scanf("%d",&a);    switch

二进制运算-十进制与二进制的转换

在学习JDK源码和JAVA一些开源框架源码的时候经常会碰到位运算,要搞懂位运算就得弄明白二进制和十进制之间的转换 一.十进制转换成二进制 1.正整数转换成二进制 十进制整数转换成二进制就是不停的除以二,直到不足二为止(0或者1),然后记录余数,从下往上排列出来就是二进制的值 举个例子:5和8转换成二进制 5的二进制为101,8的二进制为1000 2.负整数转换成二进制 负整数转换成二进制,首先取得它绝对值的正数的二进制,然后取反(0变1,1变0),然后加1 举个例子:-5的二进制(32位计算机中

20180417_十进制与二进制的转换

一.十进制转二进制 1.正数 十进制转二进制的方法是递归除2,直到商等于0停止,倒序取余数:二进制通常呈4位.8位.16位.32位出现,高位不足补0: 以十进制55为例: 最终得到的二进制数值为  11 0111 ,高位补0最终得到  0011 0111: 2.负数 负数转二进制需要先将负数取反得到正的十进制数值,之后根据正数的规则转换成二进制,再将二进制取反后加1: 以十进制-55为例: ① 取反得到数值55 ② 55转换二进制为 0011 0111 ③ 将 0011 0111 取反得到 11

Java 控制台做个十进制和二进制互相转换

计算机使用的是二进制,计算机只认识0和1 我们日常使用的是十进制,满十进一 既然计算机只认识0和1,那么我们日常使用的计算机时如何操作呢 这就需要一套二进制和十进制互相转换的公式了 首先说十进制转换二进制,就是不断的用十进制的数字除以2,直到十进制的数字最后为0时,将余数倒序排列就是十进制的二进制表示了 如下,十进制数字12转换为二进制 12 / 2 = 6 余数为 0 6 / 2 = 3   余数为 0 3 / 2 = 1   余数为 1 1 / 2 = 0   余数为 1 然后将余数倒序连起

十进制和二进制之间的相互转化

/* * * 每一个位上对应的数字 * …… 10 9 8 7 6 5 4 3 2 1 0 分别表示2的N次方 * …… 1024 512 256 128 64 32 16 8 4 2 1 * * 二进制转十进制 * 100100001 * 1 0 0 1 0 0 0 0 1 * 256 0 0 32 0 0 0 0 1 * 100100001=256+32+1=289 为零则表示该位上没有数字 ,个位数是1该数一定是基数.例如100100000则等于256+32=288 * * * 十进制转二