【Hot 100 刷题计划】 LeetCode 169. 多数元素 | C++ 哈希表基础解法

LeetCode 169. 多数元素

📌 题目描述

题目级别:简单

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

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

  • 示例 1:

    输入:nums = [3,2,3]

    输出:3

  • 示例 2:

    输入:nums = [2,2,1,1,1,2,2]

    输出:2


💡 破题思路:哈希表频率统计

这是最符合直觉的解法。我们要找出现次数最多的元素,直接用一个"小本本"把每个数字出现的次数记下来就好了。

遍历数组,将每个元素存入哈希表中并记录其出现频率。最后再遍历一次哈希表,找出那个出现次数大于 n / 2 的数字即可。

⚠️ 面试避坑点:

在 C++ 中,务必使用 unordered_map 而不是 mapmap 的底层是红黑树,插入和查找都是 O(log N) 的时间复杂度;而 unordered_map 的底层是哈希表,能够做到真正的 O(1),保证整体算法跑进线性时间。


💻 C++ 代码实现 (哈希表法)

cpp 复制代码
class Solution {
public:
    int majorityElement(vector<int>& nums) {
        // 使用 unordered_map 保证 O(1) 的存取时间
        unordered_map<int, int> mp;
        int n = nums.size();

        // 第一次遍历:统计所有元素的频率
        for (int i = 0; i < n; i ++ )
        {
            mp[nums[i]] ++ ;
        }

        // 第二次遍历:找到频率大于一半的那个多数元素
        for (auto tt : mp)
        {
            if (tt.second > n / 2) return tt.first;
        }

        return -1; // 因为题目保证一定有多数元素,理论上不会走到这里
    }
};
相关推荐
穿条秋裤到处跑4 小时前
每日一道leetcode(2026.04.29):二维网格图中探测环
算法·leetcode·职场和发展
Merlos_wind4 小时前
HashMap详解
算法·哈希算法·散列表
汉克老师5 小时前
GESP2025年3月认证C++五级( 第三部分编程题(1、平均分配))
c++·算法·贪心算法·排序·gesp5级·gesp五级
智者知已应修善业8 小时前
【51单片机2个按键控制流水灯运行与暂停】2023-9-6
c++·经验分享·笔记·算法·51单片机
云泽8089 小时前
C++11 核心特性全解:列表初始化、右值引用与移动语义实战
开发语言·c++
水蓝烟雨10 小时前
1931. 用三种不同颜色为网格涂色
算法·leetcode
AI进化营-智能译站10 小时前
ROS2 C++开发系列12-用多态与虚函数构建可扩展的ROS2机器人行为模块
开发语言·c++·ai·机器人
Morwit10 小时前
QML组件之间的通信方案(暴露子组件)
c++·qt·职场和发展
qeen8710 小时前
【数据结构】建堆的时间复杂度讨论与TOP-K问题
c语言·数据结构·c++·学习·
图码10 小时前
如何用多种方法判断字符串是否为回文?
开发语言·数据结构·c++·算法·阿里云·线性回归·数字雕刻