Problem: 136. 只出现一次的数字
文章目录
- 题目描述
- 思路
- 复杂度
- Code
题目描述
思路
由于题目要求使用线性时间复杂度和常量级的空间复杂度,再加上找重复元素这个特性,我们可以想到使用位运算来求解:
1.任何数与其本身异或得0,任何数与0异或得到其本身
2.由于只有一个数字出现一次,其余的数均出现两次,则定义int变量temp初始化为0,循环每次与nums[i]异或,最终返回temp,即为只出现一次的数
复杂度
时间复杂度:
O ( n ) O(n) O(n);其中 n n n为数组nums的大小
空间复杂度:
O ( 1 ) O(1) O(1)
Code
class Solution {
public:
/// <summary>
/// Find a number that only appears once
/// </summary>
///
/// <param name="nums"> The given array </param>
/// <returns> int </returns>
int singleNumber(vector<int>& nums) {
int temp = 0;
for (int i = 0; i < nums.size(); ++i) {
temp ^= nums[i];
}
return temp;
}
};