给定一个非空整数数组,除了某个元素只出现一次以外,其余每个元素均出现两次。找出那个只出现了一次的元素。
说明:
你的算法应该具有线性时间复杂度。 你可以不使用额外空间来实现吗?
思路(一开始做不出来,看到别人的觉得真的牛逼):
利用^相同的数都是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);
}
}

博客围绕一个非空整数数组展开,除一个元素仅出现一次外,其余元素均出现两次。要求算法有线性时间复杂度且不使用额外空间,给出思路,如通过异或运算 1^2^2^3^1^2 可找出只出现一次的元素 3。
2386

被折叠的 条评论
为什么被折叠?



