LeetCode 136. Single Number 解题报告

LeetCode 136. Single Number 解题报告

题目描述

Given an array of integers, every element appears twice except for one. Find that single one.


示例

[1] 返回1.
[2, 4, 6, 2, 4] 返回6.


限制条件

Your algorithm should have a linear runtime complexity. Could you implement it without using extra memory?


解题思路

我的思路:

使用一个set存储数组中的元素,当元素第一次出现时就放入到set中,当元素第二次出现时就从set中删除该元素,最后set中仅剩下一个只出现一次的元素,返回该元素即可。
虽然这种算法时间上满足要求,但是空间上却没有到达要求。尝试提交,是可以通过的,但不是最好的解法。下面是通过后查找到的更优的解法。

参考思路:

这道题的标签是Bit Manipulation。所以用到是位运算。其中异或运算具有以下性质:
0N=N
NN=0
所以有以下等式成立:
    0N1N2N3N2N3
=0(N2N2)(N3N3)N1
=0(0)(0)N1
=N1
因此只要设置一个变量,依次与数组中的每个元素异或,最后该变量的值会等于只出现一次的元素的值。
这算法无论是时间还是空间上都是最优的。


代码

我的代码
class Solution {
public:
    int singleNumber(vector<int>& nums) {
        set<int> elements;
        for (int i = 0; i < nums.size(); i++) {
            if (elements.find(nums[i]) == elements.end()) {
                elements.insert(nums[i]);
            } else {
                elements.erase(nums[i]);
            }
        }
        return *(elements.begin());
    }
};
参考代码
class Solution {
public:
    int singleNumber(vector<int>& nums) {
        int single = 0;
        for(auto n: nums) 
            single ^= n;
        return single;
    }
};

总结

最近做的题目都是跟位操作运算有关的,异或运算真的是有各种神奇的效果,又记下了一种异或运算的使用,真是不错不错,当把位操作的相关题目都做完了,得好好写个总结的文章。
继续勇敢地迈向下一个坑,加油!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值