点击蓝色“五分钟学算法”关注我哟

加个“星标”,一起学算法

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

最后一种解法 Cool !!!

题目描述

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

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

示例 1:

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

示例 2:

输入: [2,2,1,1,1,2,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;            }        }      }}    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;  }}    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 的。

所以可以这样操作:

动画描述

代码实现

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;  }}    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)。


本文相关阅读推荐:

毕业十年后,我忍不住出了一份程序员的高考试卷

一道腾讯面试题:厉害了我的杯

十大经典排序算法动画与解析,看我就够了

这或许是东半球分析十大排序算法最好的一篇文章

面试官,我会写二分查找法!对,没有 bug 的那种!

看《长安十二时辰》可以了解哪些算法知识

GitHub 标星 3w+,很全面的算法和数据结构知识

独乐乐不如众乐乐,如何装逼的求众数相关推荐

  1. 梦幻新诛仙微信绑定没有服务器,独乐乐不如众乐乐,在《梦幻新诛仙》里交朋友居然这么简单?...

    原标题:独乐乐不如众乐乐,在<梦幻新诛仙>里交朋友居然这么简单? 说到社交游戏,可能大家对于这个概念并不是很能理解,但要说到偷菜肯定是家喻户晓的.这也是游戏里最早期的社交方式.随着游戏行业 ...

  2. 独乐乐不如众乐乐,这三款国产优质软件,你值得拥有

    不少人对国产软件的印象,基本上都是:各种弹窗.全家桶,防不胜防,暗地里还捆绑软件. 这些流氓软件,确实是把国产的脸都丢尽了,搞得大家终日惶惶,身心俱疲. 不过,如果因为这些流氓软件,而放弃了那些一直在 ...

  3. 洛可可孟宪志:商业、设计和美学并不冲突 独乐乐不如众乐乐

    每次来到人称"北京硅谷"的望京,都会被迅速迁移过来的互联网logo惊讶到,而已经立在这里十年的LKK设计大厦,反倒像个中年大叔,沉稳中带点故事.走进大门,右侧一整面墙上挂满千奇百怪 ...

  4. PHP首期基础班郊游记:独乐乐不如众乐乐

    原文地址:http://cd.itcast.cn/news/20140823/16561230382.shtml 近日,接连几天的雨水天气给这个"焦躁"的城市降了降"火& ...

  5. 独乐乐不如众乐乐,4款名不见经传的精品软件,一个比一个好用

    众所周知,如今的软件行业,蓬勃发展,正呈一派千帆竞发的景象,无数令人目眩的软件神器,也由此诞生. 咱们今天话不多说,直接上干货. 四款珍藏多年的精品软件,笔者在此,一并奉上. BookxNote Pr ...

  6. 发现了一个好网站.绝不是打广告,独乐乐不如众乐乐.

    地址在此栈溢出的镜像站点,还翻译了的 我不是在找stackoverflow的镜像吗?别人就说了一个.很好.

  7. 独乐乐不如众乐乐---二建通过啦~

    成功永远留给准备的人,只有尝过汗水的咸,才能体会目标达成的甜! 长文预警:本篇分享内容稍长,对筒子们的耐心是个考验,能耐住性子认真看完的有两种人:一是好奇的人,二是志同道合的人.筒子们属于那种人呢,哈 ...

  8. 我白嫖了腾讯一万块,独乐乐不如众乐乐!

    既然已经点进来了,那就先不说废话,直接领取一波我的红包封面! 如果没有领到,可以在文末查看第二个领取方法. 废话开始... 事情是这样的,前几天我突然收到了公众号的官方通知,大意就是我能定制红包封面了 ...

  9. 独乐乐不如众乐乐,你的项目还在纠结用日志打印log么?Android开发okhttp3便捷拦截监听

    SimpleInterceptor SimpleInterceptor 是Android OkHttp客户端的的拦截接口工具,为的是方便测试或开发,快速查找问题. 环境要求 Android 4.1+ ...

最新文章

  1. html5 canvas 不兼容safari浏览器_HTML5的介绍
  2. lda 可以处理中文_用python处理文本数据
  3. 最全CSS各种布局详解
  4. 通过实例讲解java接口和抽象类的特殊实现方法
  5. 手游接入Facebook的那些坑
  6. LeetCode 44.通配符匹配(动态规划)
  7. [Done][DUBBO] dubbo Thread pool is EXHAUSTED!
  8. 安装10gR2的硬件要求
  9. java动态规划法实例_动态规划法实现找零 java
  10. 三菱f800变频器 频率设定_三菱F800变频器调试参数总结.docx
  11. 2022年美容师(初级)操作证考试题库及模拟考试
  12. python--RGB转HSV
  13. laravel的seeder数据填充
  14. 《研磨设计模式》 与 《设计模式之禅》对比
  15. mysql 查询上一周每一天的数据(含跨年问题)
  16. ITUNE清理“其他”的内容
  17. c语言 rpg游戏,浅谈RPG游戏设计(一)
  18. php数组时按值传递还是按地址传递
  19. React之官网首页篇
  20. python如何关闭excel窗口_EXCEL应用程序窗口未关闭工作簿。关闭()

热门文章

  1. 达观数据推荐算法实现:协同过滤之item embedding
  2. html表格隐藏和显示行,html表格怎么隐藏行
  3. MarkDown learn的Typora工具简介使用说明
  4. python字典及基本操作
  5. 如何零基础学习“人工智能”?
  6. Base64与百分号编码相关 - iOS
  7. 冯诺依曼计算机缺点,冯。诺依曼型计算机的缺点及改进方法.docx
  8. 软工第三次作业——结对编程之最长单词链
  9. 使用哈工大LTP测试分词并且增加自定义字典
  10. BGP服务器在什么业务场景会被用到?