给定一个非空整数数组,除了某个元素只出现一次以外,其余每个元素均出现两次。找出那个只出现了一次的元素。
说明:
你的算法应该具有线性时间复杂度。 你可以不使用额外空间来实现吗?
思路(一开始做不出来,看到别人的觉得真的牛逼):
利用^相同的数都是0,0和任何数字异或都是本身的性质
比如1^2^2^3^1^2 = 3,就是最终的那个数字
* Description:给定一个非空整数数组,除了某个元素只出现一次以外,其余每个元素均出现两次。找出那个只出现了一次的元素。
说明:
你的算法应该具有线性时间复杂度。 你可以不使用额外空间来实现吗?
* User: hhj
* Date: 2018-08-24
* Time: 19:27
*/
public class SingleNumber {
//利用^相同的数都是0,0和任何数字异或都是本身的性质
public static int singleNumber(int[] nums) {
int result = 0;
for(int number: nums){
result = result ^ number;
System.out.println(result);
}
return result;
}
public static void main(String[] args){
int[] nums = {1,2,6,4,4,8,1,2,6};
int res = singleNumber(nums);
System.out.println(res);
}
}