在 Python 中为每个查询找到最大异或的程序
假设我们有一个数组,它被预先排序,称为nums,大小为n,也有一个值b。我们要执行以下查询n次-
搜索非负值k<2^m使得nums和k中所有元素的XOR最大化。所以k是第i个查询的答案。
从当前数组nums中删除最后一个元素。
我们必须找到一个数组答案,其中answer[i]是第i个查询的答案。
所以,如果输入像nums=[0,1,1,3],m=2,那么输出将是[0,3,2,3],因为
nums=[0,1,1,3],k=0因为0XOR1XOR1XOR3XOR0=3。
nums=[0,1,1],k=3因为0XOR1XOR1XOR3=3。
nums=[0,1],k=2因为0XOR1XOR2=3。
nums=[0],k=3因为0XOR3=3。
示例
让我们看看以下实现以获得更好的理解-
def solve(nums, m):
x=2**m-1
for i in range(len(nums)):
nums[i]^= x
x = nums[i]
return(nums[::-1])
nums = [0,1,1,3]
m = 2
print(solve(nums, m))输入
[0,1,1,3], 2输出结果
[0, 3, 2, 3]
热门推荐
10 圣诞祝福语简短小学
11 祖国七十华诞简短祝福语
12 老师送的祝福语简短
13 生日祝福语大全女生简短
14 祝女性生日祝福语简短
15 牛年女神节祝福语简短
16 情人表白祝福语简短大气
17 老公开业祝福语简短
18 官宣新年祝福语简短