169. Majority Element


 Boyer-Moore 算法的详细步骤:

我们维护一个候选众数 candidate 和它出现的次数 count。初始时 candidate 可以为任意值,count 为 0;

我们遍历数组 nums 中的所有元素,对于每个元素 x,在判断 x 之前,如果 count 的值为 0,我们先将 x 的值赋予 candidate,随后我们判断 x:

如果 x 与 candidate 相等,那么计数器 count 的值增加 1;

如果 x 与 candidate 不等,那么计数器 count 的值减少 1。

在遍历完成后,candidate 即为整个数组的众数。


public int majorityElement(int[] nums) {
        Integer candidate = null;
        int count = 0;

        for (int x : nums) {
            if (count == 0) candidate = x;

            if (candidate == x) count++;
            else                count--;
        }
        return candidate;
    }

public int majorityElement(int[] nums) {
        Map<Integer, Integer> map = new HashMap<>();
        int n = nums.length;
        if (n == 1) return nums[0];
        
        for (int x : nums) {
            if (map.containsKey(x)) {
                int count = map.get(x);
                if (count+1 > n / 2 ) return x;
                map.put(x, count+1);
            } else {
                map.put(x, 1);
            }
        }
        return -1;
    }
©️2020 CSDN 皮肤主题: 大白 设计师:CSDN官方博客 返回首页