数据结构与算法《二》
真理只有一个,它不在宗教中,而是在科学中。 ---达芬奇
LeetCode: 只出现一次数字
给定一个非空整数数组,除了某个元素只出现一次以外,其余每个元素均出现两次。找出那个只出现了一次的元素。
说明:
- 使用线性时间复杂度,不使用额外空间。
示例:
输入: [2,2,1]
输出: 1
分析:
由于对时间复杂度和空间有限制,显然不能进行两次遍历和另开辟空间,这块考察位运算,相同的两个数做异或运算,结果为0,因为数组中除了一个元素只出现一次外,其他元素都出现两次,如果把所有的数都异或,相同的数字异或为0,最后只剩下出现一次的数字,它和0异或,结果就是它本身。
Code:
class Solution {
public int singleNumber(int[] nums) {
int num = 0;
for(int i = 0; i < nums.length; i++){
num = num ^ nums[i];
}
return num;
}
}
定期分享大数据与知识图谱相关知识点: