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;
    }
};

总结

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

你可能感兴趣的:(LeetCode)