问题描述
给定一个非空整数数组,除了某个元素只出现一次以外,其余每个元素均出现两次。找出那个只出现了一次的元素。
说明:
你的算法应该具有线性时间复杂度。 你可以不使用额外空间来实现吗?
个人思路
第一种
- 先将数组排序
- 把首尾因素考虑进去
- 用for循环查找,该元素与左右元素是否相等
第二种:异或
- 原理:二进制数中各位数相同为0,不同为1
代码如下
第一种
import java.util.Arrays;
class Solution {
public int singleNumber(int[] nums) {
Arrays.sort(nums);
if(nums.length == 1) return nums[0];
if(nums[0] != nums[1]) return nums[0];
if(nums[nums.length-1] != nums[nums.length -2]) return nums[nums.length-1];
for (int i = 1; i < nums.length-1; i++){
if (nums[i] != nums[i-1] && nums[i] != nums[i+1]){
nums[0] = nums[i];
break;
}
}
return nums[0];
}
}
第二种
class Solution {
public int singleNumber(int[] nums) {
int ans = nums[0];
if (nums.length > 1){
for (int i = 1; i < nums.length; i++){
ans = ans ^ nums[i];
}
}
return ans;
}
}