题目描述:
给定一个非空整数数组,除了某个元素只出现一次以外,其余每个元素均出现两次。找出那个只出现了一次的元素。
说明:
你的算法应该具有线性时间复杂度。 你可以不使用额外空间来实现吗?
方法一:
先排序,再遍历排序后的数组,即可找出只出现了一次的元素
但是这是方法的时间复杂度无法达到线性
方法二:
由于要求要达到线性的时间复杂度,而且不能使用额外的空间,可以考虑位运算
异或运算:
-
交换律:a ^ b ^ c <=> a ^ c ^ b
-
任何数于0异或为任何数 0 ^ n => n
-
相同的数异或为0: n ^ n => 0
class Solution {
public int singleNumber(int[] nums) {
int num =nums[0];
for (int i=1;i<nums.length;i++){
num = nums[i] ^ num;
}
return num;
}
}