【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; // 因为题目保证一定有多数元素,理论上不会走到这里
    }
};
相关推荐
Curvatureflight7 小时前
前端国际化 i18n 落地实践:语言包、动态文案和格式化问题怎么处理?
前端·c++·vue
黄小白的进阶之路7 小时前
C++提高编程---3.9 STL-常用容器-map/multimap 容器【P231~P235】
c++
WBluuue7 小时前
Codeforces 1096 Div3(ABCDEFGH)
c++·算法
誰能久伴不乏7 小时前
ibmodbus “Invalid argument“ 错误的排查与修复
c++·qt·modbus
basketball6167 小时前
Kadane算法 C++实现
java·c++·算法
handler017 小时前
【C++】二叉搜索树详解及其模拟实现(代码)
开发语言·c++·算法·c··二叉搜索树·搜索树
luj_17687 小时前
残熵算法的稳健防灾逻辑
c语言·开发语言·c++·经验分享·算法
玖釉-7 小时前
二叉树基础详解:TreeNode、buildTree、deleteTree 与 printTree 的实现原理(C++)
c++·windows·算法
QiLinkOS8 小时前
从技术到资产的跃迁:企业专利布局的深层逻辑
c语言·数据结构·c++·单片机·嵌入式硬件·算法·开源
磊 子8 小时前
STL之deque和list以及两者与vector的对比
开发语言·c++·list