数字游戏中先手胜负判断及最小制胜数字求解的 C++ 实现
以下是解决该问题的 C++ 代码: ```cpp #include <iostream> #include <vector> #include <algorithm> // 找出一个数的所有非 1 和它本身的因数 std::vector<int> findFactors(int num) { std::vector<int> factors; for (int i = 2; i * i <= num; ++i) { if (num % i == 0) { factors.push_back(i); if (i != num / i) { factors.push_back(num / i); } } } std::sort(factors.begin(), factors.end()); return factors; } // 判断先手是否能胜利,并找出第一次写出的可以制胜的最小数字 std::pair<int, int> canWin(int Q) { std::vector<int> factors = findFactors(Q); if (factors.empty()) { return {1, 0}; } for (int factor : factors) { std::vector<int> subFactors = findFactors(factor); if (subFactors.empty()) { return {1, factor}; } } return {2, 0}; } int main() { int Q; std::cin >> Q; auto result = canWin(Q); std::cout << result.first << std::endl; if (result.first == 1) { std::cout << result.second << std::endl; } return 0; } ``` ### 代码解释 1. **`findFactors` 函数**:该函数用于找出一个数的所有非 1 和它本身的因数。通过遍历从 2 到该数的平方根的所有数,若能整除该数,则将其作为因数添加到向量中,同时若该因数与商不相等,也将商添加到向量中。最后对向量进行排序。 2. **`canWin` 函数**:该函数用于判断先手是否能胜利,并找出第一次写出的可以制胜的最小数字。首先调用 `findFactors` 函数找出给定数字的所有非 1 和它本身的因数。若没有因数,则先手胜利,第一次写出的数字为 0。然后遍历这些因数,对于每个因数,再次调用 `findFactors` 函数找出其非 1 和它本身的因数。若某个因数没有非 1 和它本身的因数,则先手可以选择该因数,从而胜利。 3. **`main` 函数**:读取输入的数字 `Q`,调用 `canWin` 函数得到结果,并输出结果。 ### 复杂度分析 - **时间复杂度**:$O(\sqrt{Q})$,主要用于找出因数。 - **空间复杂度**:$O(\sqrt{Q})$,主要用于存储因数。 ######[AI问答 | 658点数解答 | 2026-03-22 20:27:16]
- C++ 实现:精准统计给定范围 [L, R] 内数字 2 出现的次数及代码详解(字节豆包 | 401点数解答 | 2026-02-05 21:17:05)38
- C++实现:统计[L, R]范围内数字2出现的次数及代码详解(字节豆包 | 489点数解答 | 2026-02-07 17:12:26)43
- Python 实现球类:精准计算半径、表面积与体积,附输入验证与异常处理!(阿里通义 | 261点数解答 | 2024-11-28 21:19:39)343
- Python:用正则表达式从含多种字符的字符串中提取英文、数字和中文单词(GPT | 522点数解答 | 2024-05-31 19:05:27)313
- Python:用正则表达式结合 split 思路提取一行字符串中的英文、数字和中文单词 (GPT | 399点数解答 | 2024-05-31 19:07:31)311
- 繁体字编码代码修改:人物名字合法性验证函数转简体版(字节豆包 | 325点数解答 | 2024-10-21 18:57:01)286
- 计算区间 n 到 m 中数字 x 出现次数的 Python 实现与详解(字节豆包 | 289点数解答 | 2025-12-07 17:14:59)72
- Python 实现:计算区间 n 到 m 中数字 x 出现的次数(字节豆包 | 322点数解答 | 2025-12-13 21:37:08)74
- 旅行售货员问题:详细步骤剖析与贪心算法Python代码实现(字节豆包 | 444点数解答 | 2024-12-17 03:32:59)276
- Dev C++ 实现旅行售货员问题:最小路程路线代码与详细解析 (字节豆包 | 448点数解答 | 2024-12-17 03:33:42)177
- C++ 求解 P1020 小核桃与删除字符串问题:双指针与枚举策略 (字节豆包 | 330点数解答 | 2026-02-07 18:40:10)25
- 51 单片机:定时器 0 实现 8 个 LED 循环点亮,附代码及优化建议(字节豆包 | 1193点数解答 | 2024-12-27 15:10:29)310