第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)。通过这道题可以体会到:同一道题,不同的解法在空间、时间复杂度上的差异,以及如何利用题目条件(比如多数元素一定存在)来优化算法
相关推荐
敲代码的嘎仔17 分钟前
力扣高频SQL基础50题详解
开发语言·数据库·笔记·sql·算法·leetcode·后端开发
小虎牙00723 分钟前
面试被问复杂度总懵?这篇指南帮你彻底搞清
算法
knight_9___2 小时前
大模型project面试4
人工智能·python·深度学习·算法·面试·agent
l1t2 小时前
DeepSeek总结的欢迎来到 ORDER BY 丛林
数据库·算法
谙弆悕博士2 小时前
【附C源码】二叉搜索树的C语言实现
c语言·开发语言·数据结构·算法·二叉树·项目实战·数据结构与算法
宵时待雨2 小时前
回溯算法专题2:二叉树中的深搜
开发语言·数据结构·c++·笔记·算法·深度优先
刀法如飞2 小时前
JavaScript 数组去重的 20 种实现方式,学会用不同思路解决问题
前端·javascript·算法
洛水水2 小时前
【力扣100题】46.单词拆分
算法·leetcode·职场和发展
MicroTech20253 小时前
量子安全赋能协同智能,微算法科技(NASDAQ :MLGO)研发PQS-BFL后量子区块链联邦学习框架
科技·算法·安全
平行侠3 小时前
A19 工业设备故障决策树智能诊断系统
算法·决策树·机器学习