136. 只出现一次的数字
题目:
给你一个 非空 整数数组 nums
,除了某个元素只出现一次以外,其余每个元素均出现两次。找出那个只出现了一次的元素。
你必须设计并实现线性时间复杂度的算法来解决此问题,且该算法只使用常量额外空间。
思路:
根据异或运算,相同的数异或会得到0,而任意一个数与0异或是本身,而且异或运算满足交换律,因此将所有数进行异或,最后剩下的数就是要找的数。
2527. 查询数组 Xor 美丽值
题目:
给你一个下标从 0 开始的整数数组
nums
。三个下标
i
,j
和k
的 有效值 定义为((nums[i] | nums[j]) & nums[k])
。一个数组的 xor 美丽值 是数组中所有满足
0 <= i, j, k < n
的三元组(i, j, k)
的 有效值 的异或结果。请你返回
nums
的 xor 美丽值。注意:
val1 | val2
是val1
和val2
的按位或。val1 & val2
是val1
和val2
的按位与。
思路:
列出所有 (i | j) & k的组合,假设有 [a,b,c,d]这样一个数组,那么它的组合有:
(a | a) & a (b | a) & a (c | a) & a (d | a) & a
(a | a) & b (b | a) & b (c | a) & b (d | a) & b
(a | a) & c (b | a) & c (c | a) & c (d | a) & c
(a | a) & d (b | a) & d (c | a) & d (d | a) & d
(a | b) & a (b | b) & a (c | b) & a (d | b) & a
(a | b) & b (b | b) & b (c | b) & b (d | b) & b
(a | b) & c (b | b) & c (c | b) & c (d | b) & c
(a | b) & d (b | b) & d (c | b) & d (d | b) & d
(a | c) & a (b | c) & a (c | c) & a (d | c) & a
(a | c) & b (b | c) & b (c | c) & b (d | c) & b
(a | c) & c (b | c) & c (c | c) & c (d | c) & c
(a | c) & d (b | c) & d (c | c) & d (d | c) & d
(a | d) & a (b | d) & a (c | d) & a (d | d) & a
(a | d) & b (b | d) & b (c | d) & b (d | d) & b
(a | d) & c (b | d) & c (c | d) & c (d | d) & c
(a | d) & d (b | d) & d (c | d) & d (d | d) & d
观察这个分块矩阵,显然是一个对称矩阵,因此这个矩阵所有值异或后即为对角线上的值进行异或,如果将对角线上的值组成一个矩阵:
(a | a) & a (b | b) & a (c | c) & a (d | d) & a
(a | a) & b (b | b) & b (c | c) & b (d | d) & b
(a | a) & c (b | b) & c (c | c) & c (d | d) & c
(a | a) & d (b | b) & d (c | c) & d (d | d) & d
由于相同值进行或和与结果不变,因此上面矩阵可以写为:
a b & a c & a d & a
a & b b c & b d & b
a & c b & c c d & c
a & d b & d c & d d
很显然,由于 & 运算左右值可以进行交换而不改变结果,因此这也是一个对称矩阵,而异或运算对于左右值相同时结果为0。这个矩阵最后异或为 abc^d。
所以对于 nums 数组,它的查询结果为 nums[i]^。