每日力扣4

136. 只出现一次的数字

题目:

给你一个 非空 整数数组 nums ,除了某个元素只出现一次以外,其余每个元素均出现两次。找出那个只出现了一次的元素。

你必须设计并实现线性时间复杂度的算法来解决此问题,且该算法只使用常量额外空间。

思路:

根据异或运算,相同的数异或会得到0,而任意一个数与0异或是本身,而且异或运算满足交换律,因此将所有数进行异或,最后剩下的数就是要找的数。

2527. 查询数组 Xor 美丽值

题目:

给你一个下标从 0 开始的整数数组 nums

三个下标 ijk有效值 定义为 ((nums[i] | nums[j]) & nums[k])

一个数组的 xor 美丽值 是数组中所有满足 0 <= i, j, k < n 的三元组 (i, j, k)有效值 的异或结果。

请你返回 nums 的 xor 美丽值。

注意:

  • val1 | val2val1val2 的按位或。
  • val1 & val2val1val2 的按位与。

思路:

列出所有 (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]^。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值