day7 作业

2019-01-02  本文已影响0人  憨猜猜

1.使用位运算判断一个数是否是奇数

number = int(input('请输入一个整数:'))
if number & 1:
    print('%d是奇数' % number)
else:
    print('%d是偶数' % number)
"""
请输入一个整数:45
45是奇数
"""

2.表达式0x13&0x17的值是(13 )

"""
0x13 = 00010011
ox17 = 00010111
0x13 & 0x17 = 00010011 & 00010111 = 00010011 = 13
"""

3.若x=-20,y=3则x&y的结果是( 0)

"""
-20 = 110100(原码)->101011(反码) ->101100(补码)
3   = 000011

x&y= -20&3= 101100 & 000011 =000000(补码)

"""

4.表达式 -97 | 120 的运算结果是(-1)

"""
-97 = 11100001(原码) = 10011110(反码) = 10011111(补码)
120 = 01111000
-97 | 120 =10011111 | 01111000 =11111111(补码)=11111110(反码)= 10000001(原码) = -1   
"""

5.在位运算中,操作数每右移一位,其结果相当于( B)

A.操作数乘以2 B.操作数除以2

C.操作数除以4 D.操作数乘以4

6.设x 是一个整数(16位).若要通过x|y使x低度8位置1,高8位不变,则y的二进制数是(0000000011111111 )

"""
x = 0000000011111111
y = 0000000011111111
x | y = 0000000011111111
"""

7.总结常用的位运算使用技巧(自己查自己,觉得好用记得住的)

&(按位与),|(按位或),~(按位取反),^(按位取反),<<(左移)

>>(右移),>>>(无符号右移)

"""
n左移(<<)k位即为n*2**k
n = 11111
print(n << 2)  # 44444
print(n * 2 ** 2)  # 44444

n右移(>>)k位即为n/2**k
n = 11111
print(n >> 2)  # 2777
print(n / 2 ** 2)  # 2777.75

计算2的k次方:2<<(k-1)
print(2 << (8 - 1))  # 256

计算n%2**k(对2的k次方取余):n &(m - 1)(m=2**k)
n=2
print(n%2**2) #2
print(n&(2**2-1)) #2

"""
# 判断奇偶性
# 原理:如果n为奇数,展开最后一位1,否则就是0
n = 3
if n & 1:
    print('奇数')  # 奇数
else:
    print('偶数')

# 取指定位
# 比如前端常见的应用,十六进制颜色转十进制

# 使用异或交换两个整数
a = 1
b = 2
a = a ^ b;
b = a ^ b;
a = a ^ b;
print(a, b)  # 2 1


# n&(n-1)将整数n的最后一位为1的位变成0
# 统计n的二进制表中1的次数
def getOnes(n):
    count = 0
    # 统计个数
    while n:
        # 满足n = 1
        n = n & (n - 1)
        # 把最后一位是一的转换成0
        count += 1
    return count


n = 0b111010101111
print(getOnes(n))  # 9

# 判断是不是2的整数次幂(1就是True,0就是False)
n = 16


def judge(n):
    if n <= 0:
        return 0
    else:
        return 1 if n & (n - 1) == 0 else 0


print(judge(n))  # 1 
上一篇 下一篇

猜你喜欢

热点阅读