使用 C++ 找出指定范围内的所有完全数
以下是一个用 C++ 编写的程序,用于找出 2 到输入的正整数 `n` 之间的所有完全数: ```cpp #include <iostream> // 判断一个数是否为完全数的函数 bool isPerfect(int num) { int sum = 0; // 找出所有除了自身以外的因子并求和 for (int i = 1; i < num; i++) { if (num % i == 0) { sum += i; } } // 判断因子之和是否等于该数本身 return sum == num; } int main() { int n; std::cout << "请输入一个正整数 n: "; std::cin >> n; std::cout << "2 到 " << n << " 之间的完全数有: "; // 遍历 2 到 n 之间的所有数 for (int i = 2; i <= n; i++) { if (isPerfect(i)) { std::cout << i << " "; } } std::cout << std::endl; return 0; } ``` ### 代码解释 1. **`isPerfect` 函数**:该函数用于判断一个数是否为完全数。它接受一个整数 `num` 作为参数,通过遍历从 1 到 `num - 1` 的所有数,找出 `num` 的所有除了自身以外的因子,并将这些因子相加得到 `sum`。比较 `sum` 是否等于 `num`,如果相等则返回 `true`,否则返回 `false`。 2. **`main` 函数**:首先,程序会提示用户输入一个正整数 `n`。然后,程序会遍历从 2 到 `n` 的所有数,对于每个数,调用 `isPerfect` 函数判断它是否为完全数。如果是完全数,则将其输出。 ### 复杂度分析 - **时间复杂度**:$O(n^2)$,其中 $n$ 是输入的正整数。这是因为对于每个数,都需要遍历从 1 到该数本身的所有数来找出其因子。 - **空间复杂度**:$O(1)$,只使用了常数级的额外空间。 ######[AI问答 | 543点数解答 | 2026-03-14 20:05:52]
- Python 实现字母与 ASCII 码的灵活转换程序(字节豆包 | 295点数解答 | 2025-11-02 16:58:48)77
- JSP 实现商品展示模块:分页、搜索、交互与美观界面全搞定!(字节豆包 | 19点数解答 | 2024-12-13 15:00:43)329
- PyCharm 中用 Selenium 编写自动化测试脚本,轻松登录 eShop 测试平台并点击“我的订单”(字节豆包 | 304点数解答 | 2024-11-06 15:38:30)429
- 详解Ackermenn函数递归实现及代码示例(字节豆包 | 289点数解答 | 2025-12-10 23:15:18)39
- 深入解析:Ackermenn函数计算的C语言实现与代码详解(字节豆包 | 392点数解答 | 2025-12-10 23:19:57)55
- Python 高效求解:让数列变身接龙数列最少需删多少数?(字节豆包 | 493点数解答 | 2025-12-13 10:25:59)55
- 深入解析格雷码生成算法:递归求解与代码实现(DeepSeek | 443点数解答 | 2026-01-05 12:21:49)46
- 无名杀1.11.0:三国杀“韬晦”技能代码详解,开发避坑指南! (百度文心 | 1168点数解答 | 2026-01-12 21:02:27)44
- 深入探究:n 位格雷码中编号 k 二进制串的求解算法与实现(DeepSeek | 726点数解答 | 2026-01-13 12:31:37)44
- Winform开发:含验证与清空功能的注册页面实现(GPT | 5266点数解答 | 2024-06-14 16:04:40)480
- jQuery 实现姓名、邮箱、电话表单验证:成功显示消息,失败提示错误(百度文心 | 858点数解答 | 2024-10-26 23:36:38)420
- jQuery实现表单验证:姓名、邮箱、电话一个都不能少!(阿里通义 | 629点数解答 | 2024-10-29 09:16:19)344