在 Python 中查找解码异或排列的程序
假设我们有一个数组enc。有一个数组perm是第一个n(odd)正整数的排列。这个列表将被编码到长度为n-1的数组enc中,这样enc[i]=perm[i]XORperm[i+1]。我们必须找到原始数组perm。
所以,如果输入像enc=[2,5,6,3],那么输出将是[7,5,0,6,5],这里[7XOR5XOR0XOR6XOR5]=[2,5,6,3]
示例
让我们看看以下实现以获得更好的理解-
def solve(enc):
n = len(enc)
result = [0] * (n+1)
x = 0
for i in range(1, n+2):
x ^= i
result[0] = x
for i in range(1, n+1, 2):
result[0] ^= enc[i]
for i in range(1, n+1):
result[i] = result[i-1] ^ enc[i-1]
return result
enc = [2,5,6,3]
print(solve(enc))输入
[2,5,6,3]输出结果
[7, 5, 0, 6, 5]
热门推荐
10 八一幼儿祝福语大全简短
11 公司乔迁食堂祝福语简短
12 婚礼结束聚餐祝福语简短
13 儿媳买车妈妈祝福语简短
14 毕业送礼老师祝福语简短
15 同事辞职正常祝福语简短
16 恭贺新婚文案祝福语简短
17 金店立秋祝福语简短英文
18 婆婆高寿祝福语大全简短