首页 > 其他 > 详细

LeetCode 136. Single Number

时间:2016-03-05 23:32:29      阅读:281      评论:0      收藏:0      [点我收藏+]

思路源于位运算关于异或^的定律:a^b^b = a, a^0 = a;

1 class Solution {
2 public:
3     int singleNumber(vector<int>& nums) {
4         int res=0;
5         for(auto num : nums)
6             res ^= num;
7         return res;
8     }
9 };

如果一个数出现两次,那么会抵消掉,只剩下那个只出现一次的数,然后与0取异或,还是它本身。

 

还有一行写法,不过是调用库函数,留坑。

LeetCode 136. Single Number

原文:http://www.cnblogs.com/co0oder/p/5246012.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!