2019.09.18爱奇艺算法岗/测试岗第二题

在这里插入图片描述

# 按位或运算
def H(a, b):
    return a|b
 按位异或运算
def Y(a, b):
    return a^b


n, m = map(int, input().split())
# 接收2的n次方个数
M = list(map(int, input().split()))
# op列表存储变换操作
op = []
for i in range(m):
    a = list(map(int, input().split()))
    op.append(a)
    
# m次操作,对应m个输出
for i in range(m):
    # 对于每次操作,需要n轮能够得到v值
    # H_flag 和 Y_flag为True的时候执行对应的位运算函数。
    # 后续操作里当一个为True时,保证另一个是False。由题知,初始时或运算先执行,所以H_flag赋值为True。
    H_flag = True
    Y_flag = False
    # 根据变换操作,对M列表更新。
    x = op[i][0]-1
    M[x] = op[i][1]
    # copy初始时的数字接收列表M以及n,避免影响到原始数据。
    MM = M[:]
    N = n
    # temp_M和a列表都是为了在执行位运算时,存储新的约简后的数据的。
    temp_M = []
    a = []
    for j in range(N, 0, -1):
        # 执行异或位运算
        if Y_flag:
            end = 2**j-1
            for p in range(0, end, 2):
                x = Y(temp_MM[p], temp_MM[p+1])
                a.append(x)
                H_flag = True
                Y_flag = False
            MM = a[:]
            a = []
            if len(MM) == 1:
                print(MM[0])
        # 执行或位运算        
        else:
            end = 2**j-1
            for p in range(0, end ,2):
                x = H(MM[p], MM[p+1])
                temp_M.append(x)
                H_flag = False
                Y_flag = True
            temp_MM = temp_M[:]
            temp_M = []
            if len(temp_MM) == 1:
                print(temp_MM[0])
    

测试1
在这里插入图片描述
测试2
在这里插入图片描述

Python位运算

按位运算符是把数字看作二进制来进行计算的。Python中的按位运算法则如下:
下表中变量 a 为 60,b 为 13,二进制格式如下:
在这里插入图片描述

本题注意点:

  • 在执行 | 或 ^ 操作时,原先的数字接收列表里的数字通过两两运算会不断减少,运算产生的新值添加到新的列表中去后,这个新列表需要作为另外一个位运算操作的数据。
  • 适当位置需要对列表清空,否则位运算产生的数会添加到自身列表,导致列表变长,从而结果列表会越来越大,得不到想要的结果。
  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值