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

P6365 [传智杯 #2 初赛] 众数出现的次数(C++)

原题链接:P6365 [传智杯 #2 初赛] 众数出现的次数 - 洛谷

题目描述

传智专修学员的课堂上,为了活跃气氛,并巩固位运算的知识,同学们玩起了一个游戏。

班级里有 n(n≤106) 名同学,每位同学都获得了两张卡,红卡或者黑卡。每张卡上都有一个不超过 109 的非负整数。第 i 位同学手里红卡数字是 ai​ ,黑卡数字是 bi​。

现在需要每位同学出牌。每位同学可以直接将红卡上的数字打出,或者将自己的红卡上的数字和自己黑卡数字进行按位异或操作后的结果打出。最后老师会收集所有同学打出的数字。

这些数字中出现次数最多的数字是众数。在所有同学合作的最优策略下,我们希望众数对应数字出现的次数尽可能多。请问出现次数最多的数字是多少呢?

输入格式

第一行,一个正整数 n。

接下来 n 行,其中第 i 行时非负整数 ai​,bi​ 代表第 i 名同学手上红卡和黑卡的数字。

输出格式

一个整数,表示答案。如果有多个解,请输出最小的那个。

输入输出样例

输入

4 21 9 28 9 28 3 17 4

输出

21

说明/提示

样例解释:

众数出现次数最多是 3 次,有如下两种方法:

  • 1 号同学直接出红卡,2 号同学出红黑异或,3 号同学随便出,4 号同学出红黑异或。这样 1,2,4 号同学都可以打出 21。
  • 1 号同学出红黑异或,2 号同学直接出红卡,3 号同学直接出红卡,4 号同学随便出。这样 1,2,3 号同学都可以打出 28。

所以 21 和 28 都是出现次数最多的众数,因为最多可以出现 3 次,不存在出现 4 次的方案。但是由于要求如果有多解输出小的,请输出 21。

以下是我的题解,利用了哈希表键值不能重复的特性统计了每个数字出现的次数,从而达到解题的目的。

#include <bits/stdc++.h> #include <unordered_map> using namespace std; int main() { int n; cin >> n; unordered_map<long long, int> count; for (int i = 0; i < n; i++) { long long a, b; cin >> a >> b; long long result = a ^ b;//计算两个数字异或的结果 if (a == result) { count[a]++; } else { count[a]++; count[result]++; } } int max = 0; long long min = 1000000001; for (auto& i : count) {//由于哈希表中的数据没有顺序的概念,所以使用auto来遍历整个哈希表 long long num = i.first;//对应前面long long类型数据 int cnt = i.second;//对应数据出现的次数 if (cnt > max) { max = cnt; min = num; } else if (cnt == max && num < min) { min = num;//当出现次数相同时,选择较小的那个数字 } } cout << min << endl; return 0; }
http://www.cnnetsun.cn/news/163849.html

相关文章:

  • Open-AutoGLM脚本编写全攻略(专家级编码规范曝光)
  • Linly-Talker模型压缩技术揭秘:在消费级显卡上流畅运行
  • 揭秘Open-AutoGLM自定义脚本编写难点:5大关键规范你必须知道
  • Linly-Talker支持MQTT协议用于物联网通信
  • Linly-Talker语音活跃度检测避免无效唤醒
  • Linly-Talker结合SLAM技术实现空间定位交互
  • 2025-12-20 全国各地响应最快的 BT Tracker 服务器(电信版)
  • Linly-Talker在养老院陪伴机器人的落地案例
  • php.ini的庖丁解牛
  • Linly-Talker与主流大模型对比:优势在哪里?
  • Linly-Talker语音中断检测机制提升交互自然度
  • Linly-Talker支持API调用,便于系统集成
  • Linly-Talker在金融投顾中的实际应用效果评估
  • Linly-Talker智谱AI GLM模型融合实验
  • 我发现自监督学习修复基因-影像缺损 罕见病早筛准确率翻倍
  • Linly-Talker MiniMax语音接口对接进展
  • 零基础也能做数字人?Linly-Talker全栈技术详解
  • 海外代理IP购买选哪家?海外动态住宅代理服务器供应商
  • Linly-Talker百度飞桨PaddlePaddle兼容性验证完成
  • PredictorsGPT:一个非预测系统的工程设计取舍与伦理边界
  • 如何避免 MySQL 死锁?——从原理到实战的系统性解决方案
  • Linly-Talker开发者激励计划上线:提交插件赢取奖励
  • 专业固液混合电容怎么选?这份指南告诉你哪个好
  • Linly-Talker驱动的AI心理陪伴机器人设想
  • Langchain-Chatchat能否支持文档加密上传解密?
  • 跨平台兼容性测试:Linly-Talker在Windows/Linux表现一致
  • Linly-Talker背后的技术栈:Transformer+Diffusion组合应用
  • Langchain-Chatchat OpenTelemetry统一观测知识平台
  • Linly-Talker支持多语言吗?中文语音合成表现实测
  • 25、Windows 容器与服务器维护全解析