C++ 实现:用贪心算法解国王游戏(弱化版),使大臣获赏最大值最小
这道题目是一个经典的贪心算法问题,需要找到一种排序方式,使得获得最多金币的大臣的金币数尽可能少。关键在于如何排序大臣的顺序。 解题思路 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. 输出结果:输出获得最多金币的大臣的金币数。 这种方法确保了大臣的顺序最优,使得最大值最小化。 ######[AI问答 | 507点数解答 | 2025-05-10 20:59:01]
- 超燃年会来袭!诗舞歌戏轮番上阵,共赴欢乐盛宴! (字节豆包 | 206点数解答 | 2025-01-08 10:59:43)343
- Python 实现球类:精准计算半径、表面积与体积,附输入验证与异常处理!(阿里通义 | 261点数解答 | 2024-11-28 21:19:39)343
- 地下水及地基土腐蚀性分析:从代码优化到逻辑完善的全面攻略(DeepSeek | 498点数解答 | 2025-06-08 21:49:49)228
- 礼盒多级排序:总价→最贵→最便宜→编号的 Python 实现与详解(阿里通义 | 1000点数解答 | 2026-03-16 12:13:21)9
- 旅行售货员问题:详细步骤剖析与贪心算法Python代码实现(字节豆包 | 444点数解答 | 2024-12-17 03:32:59)275
- Dev C++ 实现旅行售货员问题:最小路程路线代码与详细解析 (字节豆包 | 448点数解答 | 2024-12-17 03:33:42)175
- C++ 求解 P1020 小核桃与删除字符串问题:双指针与枚举策略 (字节豆包 | 330点数解答 | 2026-02-07 18:40:10)23
- 51 单片机:定时器 0 实现 8 个 LED 循环点亮,附代码及优化建议(字节豆包 | 1193点数解答 | 2024-12-27 15:10:29)310
- Python 实现贪心算法:巧解找零钱问题及需注意要点 (字节豆包 | 398点数解答 | 2025-01-04 18:06:11)118
- C++ 破解“国王游戏”弱化版:贪心排序算法巧求最少最大奖赏(DeepSeek | 550点数解答 | 2025-04-28 18:16:50)396
- 巧妙贪心排序:解决国王游戏中大臣奖赏最大化问题(DeepSeek | 1002点数解答 | 2025-05-10 20:58:15)192
- C++ 实现:用贪心算法解国王游戏(弱化版),使大臣获赏最大值最小(DeepSeek | 507点数解答 | 2025-05-10 20:59:01)174