第12天 多数元素

题意: 给定一个大小为 n 的数组 nums ,返回其中的多数元素。多数元素是指在数组中出现次数 大于 ⌊ n/2 ⌋ 的元素。 你可以假设数组是非空的,并且给定的数组总是存在多数元素。

题目链接:https://leetcode.cn/problems/majority-element/

官方题解:https://leetcode.cn/problems/majority-element/solutions/146074/duo-shu-yuan-su-by-leetcode-solution/

一、看到题目的第一想法

这道题的核心是找到数组中出现次数超过一半的元素,也就是「多数元素」。

  1. 最直接的思路:既然要统计出现次数,那用一个哈希表(unordered_map)来记录每个数字出现的次数,再遍历一次哈希表找到次数大于 n/2 的元素即可。
  2. 题目隐含的条件:多数元素一定存在,且只有一个,所以不用处理找不到的情况。
  3. 优化直觉:边统计边记录当前的 "候选多数元素" 和它的次数,不用等统计完再遍历哈希表,一次循环就能解决。

二、实现过程中遇到的困难

  1. 哈希表的使用细节 一开始可能会忘记 unordered_map 中不存在的键,直接访问时会默认初始化为 0,所以 ++counts[num] 是安全的,但如果没理解这一点,可能会额外写很多判断逻辑。
  2. 边统计边更新的逻辑误区一开始可能会想 "先把所有次数统计完,再遍历哈希表找最大值",但这样需要两次循环,而题目中的写法是一次循环内完成统计和更新,更高效。难点在于理解:只要当前元素的计数超过了当前记录的最大计数,就更新候选元素,最终的候选元素一定是多数元素。
  3. 时间与空间复杂度的取舍 哈希表解法的空间复杂度是 O(n),而题目有更优的「摩尔投票法」可以做到 O(1) 空间。一开始只想到了哈希表,忽略了更优解法,也是一个常见的思维局限。
  4. 边界条件处理比如数组长度为 1 时,直接返回唯一元素即可,不过哈希表的写法天然能处理这种情况,不会出错。

三、今日收获心得

  1. 哈希表是统计频次的通用工具 对于 "统计元素出现次数" 的问题,哈希表是最直接的解法,它能以 O(1) 的平均时间复杂度完成增删改查,非常适合这类统计问题。
  2. 一次遍历的优化思路 题目中的写法把「统计次数」和「更新候选多数元素」合并到了一次循环里,避免了二次遍历,时间复杂度保持 O(n),但常数更小,这种边遍历边更新状态的思想很实用。
  3. 理解 "多数元素" 的特殊性质多数元素的出现次数超过一半,所以它的计数在整个数组中一定是最高的,这也是为什么边统计边更新候选元素的方法一定能找到正确答案。
  4. 算法题的解法对比思维 除了哈希表解法,这道题还有更优的「摩尔投票法」,空间复杂度 O(1)。通过这道题可以体会到:同一道题,不同的解法在空间、时间复杂度上的差异,以及如何利用题目条件(比如多数元素一定存在)来优化算法
相关推荐
Jerry6 小时前
LeetCode 209. 长度最小的子数组
算法
彦为君7 小时前
算法思维与经典智力题
java·前端·redis·算法
智能优化与强化学习7 小时前
Gym(Gymnasium)仿真环境详解(二):环境简介、入门算法、调参要点、核心挑战
算法·强化学习·gym·零基础入门·算法评估
mxwin7 小时前
Unity Shader exp 函数的算法与渲染应用
算法·unity·游戏引擎·shader
“码”力全开7 小时前
AI视频分析误报优化完整流程
算法·架构·边缘计算
深盾科技_Virbox7 小时前
深盾科技·Virbox产品体系全景解读:软件安全如何从加密锁走向全生命周期
java·大数据·算法·安全·软件需求
可编程芯片开发8 小时前
基于VSG虚拟同步发电机控制的三相并网逆变器带多组可变负载Simulink建模与仿真
算法
AI服务老曹8 小时前
国产NPU视觉算法参数配置说明
算法·性能优化·边缘计算
彦为君8 小时前
Redis最新版本特性
java·数据库·redis·算法·bootstrap
触底反弹8 小时前
🔥 字符串算法面试三连击:反转、回文、回文变种,搞懂这三题稳了!
前端·javascript·算法