赞
踩
Problem: 136. 只出现一次的数字
由于题目要求使用线性时间复杂度和常量级的空间复杂度,再加上找重复元素这个特性,我们可以想到使用位运算来求解:
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)
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; } };
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。