【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; // 因为题目保证一定有多数元素,理论上不会走到这里
    }
};
相关推荐
米粒12 小时前
力扣算法刷题 Day 38 (打家劫舍专题)
算法·leetcode·职场和发展
暴力求解2 小时前
C++ ---string类(三)
开发语言·c++
say_fall2 小时前
有关算法的简单数学问题
数据结构·c++·算法·职场和发展·蓝桥杯
XiYang-DING3 小时前
【Java】哈希
java·哈希算法·散列表
m0_716765233 小时前
数据结构--顺序表的插入、删除、查找详解
c语言·开发语言·数据结构·c++·学习·算法·visual studio
say_fall3 小时前
滑动窗口算法
数据结构·c++·算法
落羽的落羽3 小时前
【算法札记】练习 | Week1
linux·服务器·c++·人工智能·python·算法·机器学习
c++圈来了个新人3 小时前
C++类和对象(上)
c语言·开发语言·数据结构·c++·考研
人道领域3 小时前
【LeetCode刷题日记】15.三数之和(梦破碎的地方)
算法·leetcode·面试