[LeetCode] Majority Element II

Given an integer array of size n, find all elements that appear more than ⌊ n/3 ⌋ times.

Note: The algorithm should run in linear time and in O(1) space.

Example 1:

Input: [3,2,3]
Output: [3]

Example 2:

Input: [1,1,1,3,3,2,2,2]
Output: [1,2]

n/3 times说明这样的数至多存在2个。

所以使用两个数n1,n2表示候选的数字,c1,c2表示这两个数出现的次数。

遍历数组,记当前数组为num,如果num与n1,n2其一相等,则对应的c1或c2加一。

如果num与n1和n2都不等,此时如果c1或c2其一为0,则令对应的候选数为num,并令其加一,

否则c1和c2各自减一,

最后再统计一次候选数字出现的次数是否大于n/3

class Solution {
public:
    vector<int> majorityElement(vector<int>& nums) {
        vector<int> res;
        if (nums.empty())
            return res;
        int n1 = nums[0], n2 = 0;
        int c1 = 1, c2 = 0;
        for (int i = 1; i < nums.size(); ++i)
        {
            if (nums[i] == n1)
                c1++;
            else if (nums[i] == n2)
                c2++;
            else
            {
                if (c1 == 0)
                {
                    n1 = nums[i];
                    c1 = 1;
                }
                else if (c2 == 0)
                {
                    n2 = nums[i];
                    c2 = 1;
                }
                else
                {
                    c1--;
                    c2--;
                }
            }
        }
        c1 = 0, c2 = 0;
        for (auto& num : nums)
        {
            if (num == n1)
                c1++;
            else if (num == n2)
                c2++;
        }
        if (c1 > nums.size() / 3)
            res.push_back(n1);
        if (c2 > nums.size() / 3 && n1 != n2)
            res.push_back(n2);
        return res;
    }
};
// 12 ms

 

posted @ 2018-06-08 22:27  immjc  阅读(132)  评论(0编辑  收藏  举报