酷代码 AI
菜单
全部AI  /  AI问答
服务商

C++ P3632国王游戏(弱化版) 入门 排序 贪心 标准IO 传统题 时间限制 1000ms 内存限制 256MB 通过/尝试次数 606/1828 来源 TomAnderson 题目描述 恰逢 H 国国庆,国王邀请 � n 位大臣来玩一个有奖游戏。首先,他让每个大臣在左、右手上面分别写下一个整数,国王自己也在左、右手上各写一个整数。然后,让这 � n 位大臣排成一排,国王站在队伍的最前面。排好队后,所有的大臣都会获得国王奖赏的若干金币,每位大臣获得的金币数分别是:排在该大臣前面的所有人的左手上的数的乘积除以他自己右手上的数,然后向下取整得到的结果。 国王不希望某一个大臣获得特别多的奖赏,所以他想请你帮他重新安排一下队伍的顺序,使得获得奖赏最多的大臣,所获奖赏尽可能的少。注意,国王的位置始终在队伍的最前面。 输入格式 第一行包含一个整数 � n,表示大臣的人数。 第二行包含两个整数 � a 和 � b,之间用一个空格隔开,分别表示国王左手和右手上的整数。 接下来 � n 行,每行包含两个整数 � a 和 � b,之间用一个空格隔开,分别表示每个大臣左手和

这道题目是一个经典的贪心算法问题,需要找到一种排序方式,使得获得最多金币的大臣的金币数尽可能少。关键在于如何排序大臣的顺序。 解题思路 1. 贪心策略:为了使最大值最小化,应该按照大臣的左右手乘积进行升序排序。即对于两个大臣i和j,如果i.left * i.right < j.left * j.right,那么i应该排在j前面。 2. 计算金币:排序后,遍历每个大臣,计算前面所有人左手数的乘积除以当前大臣右手数,取整后记录最大值。 代码实现 ```cpp #include <iostream> #include <vector> #include <algorithm> using namespace std; struct Minister { int left; int right; int product; }; bool compare(const Minister &a, const Minister &b) { return a.product < b.product; } int main() { int n; cin >> n; int kingLeft, kingRight; cin >> kingLeft >> kingRight; vector<Minister> ministers(n); for (int i = 0; i < n; ++i) { cin >> ministers[i].left >> ministers[i].right; ministers[i].product = ministers[i].left * ministers[i].right; } sort(ministers.begin(), ministers.end(), compare); int maxCoin = 0; int product = kingLeft; for (int i = 0; i < n; ++i) { int coin = product / ministers[i].right; if (coin > maxCoin) { maxCoin = coin; } product *= ministers[i].left; } cout << maxCoin << endl; return 0; } ``` 代码解释 1. 结构体定义:`Minister`结构体存储每个大臣的左右手数值及其乘积。 2. 排序函数:`compare`函数按照左右手乘积升序排序。 3. 输入处理:读取国王和大臣的数据,计算每个大臣的乘积。 4. 排序:使用`sort`函数对大臣进行排序。 5. 计算金币:初始化乘积为国王的左手数,遍历每个大臣,计算金币并更新最大值。 6. 输出结果:输出获得最多金币的大臣的金币数。 这种方法确保了大臣的顺序最优,使得最大值最小化。 [2025-05-10 20:59:01 | AI问答 | 507点数解答]

热门AI查看更多
“AI写代码神器”擅长各种语言编程、解释代码、注解补充。 在这里填写你的问题。如:写出java冒泡排序算法。
一个入口掌握所有。 在这输入任何问题,或者要AI输出的内容。
将阿拉伯数字转为人明币大写,如:数字1000转换为壹仟。
AI生成爆文标题,能够快速创作出极具吸引力的标题,促使短视频、自媒体文章的点击率与阅读量迅猛攀升。 此处填写一个原始标题,如:一般人怎样打理自身的社交圈?
AI生成新闻评论。 在这里填入新闻内容。
AI生成内容摘要。 在此处填入需要生成摘要的内容,还可以输入4000字。
AI生成主持词,擅长团建、年会、婚礼、节日等场合的主持词编写。 在这里填入主持场景,如:运动会
AI快速生成周报、月报、日报、年终总结等各类总结报告。 在这里简单输入工作目标、指标、成果,没有任何格式或特殊需求。如:计划年销售业绩1000万,实际完成800万。
输入一个字,显示以这个字开头的歇后语
输入一个字,显示以这个字开头的成语
极速在线生成证件照
极速更换证件照红、蓝、白底色
实用工具查看更多
数独游戏 [娱乐类]
数独(Sudoku)是经典的9x9数字逻辑谜题。在有81个小格的九宫格内,玩家依据初始数字推理填入1 - 9的数字,要保证每行、每列以及每个3x3宫格中的数字都不重复。这款在线数独游戏有多难度可选,没有头绪时,可以点开答案看一下哦^_^
3D魔方 [娱乐类]
基于three.js的小游戏,锻炼玩家的眼力和反应力,非常不错
经典推箱子 [娱乐类]
基于H5的经典推箱子小游戏,锻炼玩家的眼力和反应力,非常不错
摸鱼五子棋 [娱乐类]
基于H5的五子棋人机对练,锻炼玩家的眼力和反应力,非常不错
速度打字机 [娱乐类]
打字速度挑战游戏可以训练玩家的打字速度与准确率。玩家要在给定时间内输入尽量多的单词或句子,从而在规定时间里争取获得最高分。
键盘打字 [娱乐类]
基于H5的键盘打字小游戏,锻炼玩家的眼力和反应力,非常不错
扫雷 [娱乐类]
基于H5的小游戏,锻炼玩家的眼力和反应力,非常不错
2048 [娱乐类]
H5版2048小游戏,锻炼玩家的前瞻力,非常不错
36万 进入2048
相关提问