力扣(LeetCode)求众数 个人题解

Posted Axiangcoding

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了力扣(LeetCode)求众数 个人题解相关的知识,希望对你有一定的参考价值。

给定一个大小为 的数组,找到其中的众数。众数是指在数组中出现次数大于 ⌊ n/2 ⌋ 的元素。

你可以假设数组是非空的,并且给定的数组总是存在众数。

示例 1:

输入: [3,2,3]
输出: 3

示例 2:

输入: [2,2,1,1,1,2,2]
输出: 2


简单的思路是用map记录数字出现的次数,最后找到出现最多次数的那个数字,这个是比较简单的思路,这里就不放代码了

算法的思路是使用 “摩尔投票法”,一种算法可以在遍历数组的过程中找到出现次数大于数组长度一半且唯一的数字。也就是本题中的众数。

摩尔投票法的介绍:https://www.jianshu.com/p/c19bb428f57a

代码如下:

class Solution {
    public int majorityElement(int[] nums) {
        int count = 0;
        int ret = nums[0];
        for (int n : nums) {
            if (count == 0)
                ret = n;
            if (n == ret)
                count++;
            else {
                count--;
            }
        }
        return ret;
    }
}

 

以上是关于力扣(LeetCode)求众数 个人题解的主要内容,如果未能解决你的问题,请参考以下文章

leetcode-169求众数

LeetCode求众数

求众数

快乐水题229. 求众数 II

快乐水题229. 求众数 II

LeetCode(169. 求众数)