LeetCode 0137 - Single Number II

2021-08-11 14:47:52 浏览数 (2)

Single Number II

Desicription

Given a non-empty array of integers, every element appears three times except for one, which appears exactly once. Find that single one.

Note:

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

Example 1:

代码语言:javascript复制
Input: [2,2,3,2]
Output: 3

Example 2:

代码语言:javascript复制
Input: [0,1,0,1,0,1,99]
Output: 99

Solution

代码语言:javascript复制
class Solution {
public:
    int singleNumber(vector<int>& nums) {
        int a = 0;
        int b = 0;
        for(auto it : nums) {
            a = (a ^ it) & ~b;
            b = (b ^ it) & ~a;
        }
        return a;
    }
};

0 人点赞