标签:return 部分 实现 tps 线性 数据结构 int 数组 single
x ^ 0s = x x & 0s = 0 x | 0s = x
x ^ 1s = ~x x & 1s = x x | 1s = 1s
x ^ x = 0 x & x = x x | x = x
感觉这得记住
利用 x ^ x = 0
利用 x & 0s = 0 和x & 1s = x 可以实现掩码操作,例如 x & 0b0011100 仅保留x中与 1 重叠的部分
利用 x | 1s = 1s 和 x | 0s = x 可实现设值操作,例如 x | 0b0011100 把x中与右边 1 相对应的部分设值为1
LeetCode:只出现一次的数字
给定一个非空整数数组,除了某个元素只出现一次以外,其余每个元素均出现两次。找出那个只出现了一次的元素。
说明:
你的算法应该具有线性时间复杂度。 你可以不使用额外空间来实现吗?
输入: [4,1,2,1,2]
输出: 4
利用 x ^ x = 0 去除两个相同的数
class Solution {
public int singleNumber(int[] nums) {
int m = 0;
for(int item : nums){
m ^= item;
}
return m;
}
}
标签:return 部分 实现 tps 线性 数据结构 int 数组 single
原文地址:https://www.cnblogs.com/buptleida/p/13051633.html