C++ 实现游戏赢家判断:巧妙找出满足和条件的最大数
我将用C++实现这个游戏判断赢家的程序。程序需要找出一个数,这个数是其他任意两个不同数之和,并且在所有满足条件的数中取最大的那个。 ```cpp #include <iostream> #include <vector> #include <algorithm> #include <unordered_set> using namespace std; int findWinner(const vector<int>& nums) { unordered_set<int> numSet(nums.begin(), nums.end()); vector<int> candidates; for (int i = 0; i < nums.size(); ++i) { bool found = false; // 检查当前数是否可以表示为其他两个不同数的和 for (int j = 0; j < nums.size() && !found; ++j) { if (j == i) continue; int target = nums[i] - nums[j]; if (target != nums[j] && numSet.count(target)) { found = true; } } if (found) { candidates.push_back(nums[i]); } } if (candidates.empty()) { return 0; } // 返回最大的候选数在原数组中的位置(1-based) int maxNum = *max_element(candidates.begin(), candidates.end()); for (int i = 0; i < nums.size(); ++i) { if (nums[i] == maxNum) { return i + 1; // 返回1-based索引 } } return 0; } int main() { int N; cin >> N; vector<int> nums(N); for (int i = 0; i < N; ++i) { cin >> nums[i]; } int winner = findWinner(nums); cout << winner << endl; return 0; } ``` 代码说明: 1. 使用哈希集合存储所有数字以便快速查找 2. 遍历每个数字,检查是否能表示为其他两个不同数字的和 3. 收集所有满足条件的数字 4. 从候选数字中找出最大的那个,返回其在原数组中的位置(1-based索引) 5. 如果没有满足条件的数字,返回0 三条额外需要注意的逻辑点: - 需要确保三个数都是不同的,即不能把一个数用两次来求和 - 当多个数满足条件时,要选择最大的那个数 - 返回的是1-based索引而不是0-based索引 ######[AI写代码神器 | 506点数解答 | 2025-06-20 16:18:09]
- 超燃年会来袭!诗舞歌戏轮番上阵,共赴欢乐盛宴! (字节豆包 | 206点数解答 | 2025-01-08 10:59:43)346
- Python 实现球类:精准计算半径、表面积与体积,附输入验证与异常处理!(阿里通义 | 261点数解答 | 2024-11-28 21:19:39)346
- C++ 实现:根据给定正整数构造 3×3 方阵并计算满足条件的方案数(阿里通义 | 875点数解答 | 2024-11-13 16:38:24)249
- C++实现:低复杂度求解 3×3 方阵构造方案数(阿里通义 | 708点数解答 | 2024-11-13 16:45:15)285
- Python 高效解决 U 王国社区端午节粽子分配数量计算问题(DeepSeek | 218点数解答 | 2025-05-31 18:33:52)199
- C++ 实现:根据家庭人数精准计算 U 王国社区粽子分配总数(DeepSeek | 250点数解答 | 2025-05-31 18:36:11)169
- 幼儿园小朋友学号奇偶分类:代码实现与详细解释(字节豆包 | 406点数解答 | 2025-11-26 19:39:05)60
- 策略游戏大揭秘:小 L 与小 Q 最优策略下每轮得分计算全解析(字节豆包 | 676点数解答 | 2025-12-12 18:49:42)64
- Python代码:简化网友国度货币系统,求解最小货币种数(字节豆包 | 529点数解答 | 2025-12-13 10:29:25)51
- 数轴旅行:从原点出发,能否到达目标位置?(字节豆包 | 225点数解答 | 2026-01-23 19:51:03)47
- Python 实现:计算特殊规则矩阵行列式并对 109+7 取模(字节豆包 | 672点数解答 | 2026-02-05 20:46:07)45
- C++ 实现:快速判断正整数是否为“超级整数”(字节豆包 | 239点数解答 | 2025-11-10 18:52:28)95