异或有三个属性-
N ^ N = 0N ^ 0 = NA ^ B = B ^ A让数组是{2,3,4,5},我正在执行2 ^ 3 ^ 4 ^ 5的异或,但答案是0。为什么是0?
PS:我认为,当存在每个数字的副本(N)时,结果总是为零,这将使异或计算成为0。有一篇文章可以使用XOR逻辑删除数组中的重复元素,因为XOR的顺序无关紧要,两个相同的数字将导致0。
编辑:根据注释中的答案,我了解到,有时候XOR操作也可以生成结果0,而不一定是复制必须存在才能使其为零。抱歉,我有点糊涂。谢谢你的回答。
发布于 2022-12-02 08:35:25
当您一步一步评估2 ^ 3 ^ 4 ^ 5时,您会得到:
2 ^ 3 1(2 ^ 3) ^ 4 == (1) ^ 4 == 5((2 ^ 3) ^ 4) ^ 5) = ((1) ^ 4) ^ 5 == (5) ^ 5 == 0在二进制文件中,为了使操作更加清晰:
按位异或:相同位变为0,不同位变为1
即使您从右到左计算:2 ^ (3 ^ (4 ^ 5)) == 2 ^ (3 ^ (1)) == 2 ^ (2) == 0
https://stackoverflow.com/questions/74652372
复制相似问题