美文网首页
独乐乐不如众乐乐,如何装逼的求众数

独乐乐不如众乐乐,如何装逼的求众数

作者: 五分钟学算法 | 来源:发表于2019-07-26 16:57 被阅读0次

今天分享的题目来源于 LeetCode 上第 169 号问题:求众数(求数组中超过一半的数字)。题目难度为 Easy,目前通过率为 45.8% 。

最后一种解法 Cool !!!

题目描述

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

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

示例 1:

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

示例 2:

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

题目解析

题目意思很好理解:给你一个数组,里面有一个数字出现的次数超过了一半,你要找到这个数字并返回。

解法一:暴力解法

遍历整个数组,同时统计每个数字出现的次数。

最后将出现次数大于一半的元素返回即可。

动画描述

代码实现

class Solution {
    public int majorityElement(int[] nums) {
        int majorityCount = nums.length/2;

        for (int num : nums) {
            int count = 0;
            for (int elem : nums) {
                if (elem == num) {
                    count += 1;
                }
            }
            if (count > majorityCount) {
                return num;
            }

        }  
    }
}

复杂度分析

时间复杂度:O(n2)

暴力解法包含两重嵌套的 for 循环,每一层 n 次迭代,因此时间复杂度为 O(n2) 。

空间复杂度:O(1)

暴力解法没有分配任何与输入规模成比例的额外的空间,因此空间复杂度为 O(1)。

解法二:哈希表法

这个问题可以视为查找问题,对于查找问题往往可以使用时间复杂度为 O(1) 的 哈希表,通过以空间换时间的方式进行优化。

直接遍历整个 数组 ,将每一个数字(num)与它出现的次数(count)存放在 哈希表 中,同时判断该数字出现次数是否是最大的,动态更新 maxCount,最后输出 maxNum。

动画描述

代码实现

class Solution {
    public int majorityElement(int[] nums) {
    Map<Integer, Integer> map = new HashMap<>();
    // maxNum 表示元素,maxCount 表示元素出现的次数
    int maxNum = 0, maxCount = 0;
    for (int num: nums) {
      int count = map.getOrDefault(num, 0) + 1;
      map.put(num, count);
      if (count > maxCount) {
        maxCount = count;
        maxNum = num;
      }
    }
    return maxNum;
  }
}

复杂度分析

时间复杂度:O(n)

总共有一个循环,里面哈希表的插入是常数时间的,因此时间复杂度为 O(n)。

空间复杂度:O(n)

哈希表占用了额外的空间 O(n),因此空间复杂度为 O(n)。

解法三:摩尔投票法

再来回顾一下题目:寻找数组中超过一半的数字,这意味着数组中其他数字出现次数的总和都是比不上这个数字出现的次数

即如果把 该众数记为 +1 ,把其他数记为 −1 ,将它们全部加起来,和是大于 0 的。

所以可以这样操作:

  • 设置两个变量 candidate 和 count,candidate 用来保存数组中遍历到的某个数字,count 表示当前数字的出现次数,一开始 candidate 保存为数组中的第一个数字,count 为 1
  • 遍历整个数组
  • 如果数字与之前 candidate 保存的数字相同,则 count 加 1
  • 如果数字与之前 candidate 保存的数字不同,则 count 减 1
  • 如果出现次数 count 变为 0 ,candidate 进行变化,保存为当前遍历的那个数字,并且同时把 count 重置为 1
  • 遍历完数组中的所有数字即可得到结果

动画描述

代码实现

class Solution {
    public int majorityElement(int[] nums) {
    int candidate = nums[0], count = 1;
    for (int i = 1; i < nums.length; ++i) {
      if (count == 0) {
        candidate = nums[i];
        count = 1;
      } else if (nums[i] == candidate) {
        count++;
      } else{
        count--;
      }
    }
    return candidate;
  }
}

复杂度分析

时间复杂度:O(n)

总共只有一个循环,因此时间复杂度为 O(n)。

空间复杂度:O(1)

只需要常数级别的额外空间,因此空间复杂度为 O(1)。

❤️ 看完三件事:

如果你觉得这篇内容对你挺有启发,我想邀请你帮我三个忙:

  • 点赞,让更多的人也能看到这篇内容(收藏不点赞,都是耍流氓 -_-)
  • 关注我和专栏,让我们成为长期关系
  • 关注公众号「五分钟学算法」,第一时间阅读最新的算法文章,公众号后台回复 1024 送你 50 本 算法编程书籍。

相关文章

  • 独乐乐不如众乐乐,如何装逼的求众数

    今天分享的题目来源于 LeetCode 上第 169 号问题:求众数(求数组中超过一半的数字)。题目难度为 Eas...

  • 【一日一句一画】0809

    独乐乐 不如众乐乐

  • 众乐乐不如独乐乐

    众乐乐不如独乐乐

  • 愚人节快乐!

    愚于人者智?愚人者愚?非也。亦求众乐也。独乐乐不如众乐乐。愚人节快乐。

  • 独乐乐,不如众乐乐

    农历古历二月十八,向来对日子大大咧咧的我,对这个日子却是心心念念。明天是美丽团庄二月十九庙会,让我一再地想起心中珍...

  • 众乐乐不如独乐乐

    小时候是个孤僻的人,常常一个人到放杂物的小屋儿安静地坐会,看一本书。上学后交往的孩子也不是很多,邻...

  • 独乐乐不如众乐乐!

    有了快乐却不能和别人分享,这或许真的是世界上最郁闷的事吧?有人说,将快乐与人分享,那么你的快乐将会加倍,将...

  • 独乐乐不如众乐乐

    含笑是他的网名,别以为他是个女人,他可是地地道道的纯爷们儿,身如塔松声如洪钟面如古铜走如旋风,和他在一起的人都被鼓...

  • 独乐乐不如众乐乐

    每年的春节前几天,那是我最忙的几天。因为一个春节,公婆的三个子女会集中在一起欢度的,只有晚上各自回家住。 我会提前...

  • 独乐乐不如众乐乐

    书名:《取悦症》—哈丽雅特 金句:过分地把自尊跟你为别人做事联系起来,这样做的一个后果是无法把任务分派给别人。 感...

网友评论

      本文标题:独乐乐不如众乐乐,如何装逼的求众数

      本文链接:https://www.haomeiwen.com/subject/nbudrctx.html