+关注
已关注

分类  

暂无分类

标签  

暂无标签

日期归档  

2019-08(58)

2019-09(95)

2019-10(18)

2019-11(2)

2019-12(17)

【python】整数的原码、反码、补码和移码实现

发布于2019-10-28 14:04     阅读(302)     评论(0)     点赞(6)     收藏(0)


0

1

2

3

4

5

6

7

8

9


在计算机中,数据以二进制表示,本文以第一个0/1表示符号位,以bin(x)表示x绝对值的二进制串,以rev(x)表示x绝对值的二进制串按位取反的二进制串。
例如:

  • bin(2)=10
  • rev(2)=01

原码

  • 正数的原码
    0,bin(x)
  • 负数的原码
    1,bin(x)

反码

  • 正数的反码
    0,bin(x)
  • 负数的反码
    1,rev(x)

补码

  • 正数的补码
    0,bin(x)
  • 负数的补码
    1,rev(x)+1

移码

  • 正数的补码
    1,bin(x)
  • 负数的补码
    0,rev(x)+1

规则

  • 0的原码反码补码相等,均为0,0
  • 正数的原码反码补码相等
  • 负数的反码等于原码的数值按位取反(符号位不变)
  • 负数的补码等于反码加1
  • 移码等于补码的符号位取反

python实现

flag=0
_s=''
def getbin(s):
    _s=bin(abs(s))
    _s=_s.replace('0b','')
    return _s

def rev(s):
    s=s.replace('1','2')
    s=s.replace('0','1')
    s=s.replace('2','0')
    return s
    
def y(s):
    print('原码是:%d,%s\t'%(flag,_s))
    
def f(s):
    global _s
    if flag==0:
        print('反码是:%d,%s\t'%(flag,_s))
        return
    _s=rev(_s)
    print('反码是:%d,%s\t'%(flag,_s))
    return

def by(s):
    global _s
    _s=int(_s,2)+1
    _s=getbin(_s)
    print('补码是:%d,%s\t'%(flag,_s))
    print('移码是:%d,%s\t'%((flag+1)%2,_s))
 
def out(s):
    y(s)
    f(s)
    by(s)

while True:
    try:
        s=int(input('请输入一个十进制整数:\n'))
        if s>=0:
            flag=0
        else:
            flag=1
        _s=getbin(s)
        out(s)
        print()
    except IOError:
        break
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
#样例
请输入一个十进制整数:
-2
原码是:1,10 
反码是:1,01 
补码是:1,10 
移码是:0,10

请输入一个十进制整数:
2
原码是:0,10 
反码是:0,10 
补码是:0,11 
移码是:1,11
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14

0

1

2

3

4

5

6

7

8

9



所属网站分类: 技术文章 > 博客

作者:83748wuw

链接: https://www.pythonheidong.com/blog/article/146919/a9e366ea0646f3e2f2e3/

来源: python黑洞网

任何形式的转载都请注明出处,如有侵权 一经发现 必将追究其法律责任

6 0
收藏该文
已收藏

评论内容:(最多支持255个字符)