当前位置: 首页 > news >正文

【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++ 代码实现 (哈希表法)

classSolution{public:intmajorityElement(vector<int>&nums){// 使用 unordered_map 保证 O(1) 的存取时间unordered_map<int,int>mp;intn=nums.size();// 第一次遍历:统计所有元素的频率for(inti=0;i<n;i++){mp[nums[i]]++;}// 第二次遍历:找到频率大于一半的那个多数元素for(autott:mp){if(tt.second>n/2)returntt.first;}return-1;// 因为题目保证一定有多数元素,理论上不会走到这里}};
http://www.jsqmd.com/news/631019/

相关文章:

  • 免费开源游戏串流终极方案:Sunshine自托管服务器完整指南
  • 告别重复劳动!用Layout2allegro批量转换PCB封装库的保姆级教程
  • 实测Stable Diffusion v1.5 Archive:单卡A10 24G显存稳定运行,生成速度超快
  • 5分钟掌握LOL身份伪装:LeaguePrank终极定制指南
  • 别再折腾原生告警了!用Alertmanager+Grafana打造更强大的飞书通知(保姆级配置)
  • 从电路到布局:深入剖析耳机串扰(Crosstalk)的成因与优化
  • TMM框架自证闭环逻辑:从公理奠基到全域递归的科学元规则
  • 一款基于 .NET 开源、跨平台应用程序自动升级组件悦
  • QuestaSim 2020.1配置Xilinx仿真库全攻略(附常见错误解决方案)
  • 2026年4月香氛品牌推荐,香薰/减压香薰/豪车香氛/油性香氛精油/瑜伽香薰/挂式香薰,香氛ODM供应厂家口碑推荐 - 品牌推荐师
  • 告别“玄学”调试:深入理解ARM Semihosting的DCC模式与性能陷阱
  • Jetson AGX Orin 新手避坑:解决‘找不到nvidia-jetpack包’的完整修复指南
  • G3810,TS3380,G1800,G2810,G4810,MG3680,IX6780,MP288,TS8380打印机废墨垫清零软件,错误代码5B00,P07,E08,1700,5b04,亲测有效。
  • YOLO-Master 与 YOLO 开始白
  • FastAPI项目半夜报警吵醒你?聊聊告警这事儿怎么搞!囤
  • Carsim/Trucksim预瞄点设置与Simulink联合仿真的变量导出实战
  • 树莓派进阶实践:基于PCF8591与热敏电阻的智能温控系统
  • STM32实战指南——SIM900A通过AT指令实现多语言短信发送
  • UniApp跨平台跳转外部链接的实战指南
  • 佳能最新清零软件ServiceTool_v6.200 ,TS3380,G1800,G2810,G3810,G4810,MG3680,IX6700,代码5B00,P07,E08,1700,5b04,有效
  • 从仿真到避坑:用Matlab Filter Design工具箱设计IIR滤波器,搞定LFM信号中的单频干扰
  • GoCodingInMyWay止
  • 终极指南:5个简单步骤免费解锁Cursor Pro完整AI编程体验
  • 【大模型落地攻坚指南】:3步实现90%参数量压缩,蒸馏后精度损失<1.2%的工业级实践
  • 2026年企业精益安全管理系统选型指南:10款主流精益安全管理软件深度盘点
  • GD32F350 SRAM启动调试全攻略:Keil工程配置避坑指南
  • CANoe_UDS-Bootloader刷写系列-含源码(一)从零构建刷写流程框架
  • 前端使用AI试水报告扇
  • 告别默认灰:用QSS为你的Qt6应用打造一套专属标签页皮肤(附完整资源文件)
  • 使用Spring AI Alibaba构建智能体Agent拔