C++实现求不大于n的正整数阶乘的和
以下是使用 C++ 解决求不大于 `n` 的正整数的阶乘的和的代码: ```cpp #include <iostream> using namespace std; // 计算阶乘的函数 int factorial(int num) { int result = 1; // 从 1 到 num 累乘得到阶乘 for (int i = 1; i <= num; ++i) { result *= i; } return result; } int main() { int n; // 读取输入的正整数 n cin >> n; int sum = 0; // 遍历从 1 到 n 的每个数 for (int i = 1; i <= n; ++i) { // 计算当前数的阶乘并累加到总和中 sum += factorial(i); } // 输出阶乘的和 cout << sum << endl; return 0; } ``` ### 代码解释 1. **`factorial` 函数**:该函数接受一个整数 `num` 作为参数,通过一个 `for` 循环从 1 到 `num` 进行累乘,最终返回 `num` 的阶乘。 2. **`main` 函数**: - 从标准输入读取一个正整数 `n`。 - 初始化一个变量 `sum` 用于存储阶乘的和。 - 使用 `for` 循环遍历从 1 到 `n` 的每个数,调用 `factorial` 函数计算当前数的阶乘,并将其累加到 `sum` 中。 - 最后输出 `sum` 的值。 ### 复杂度分析 - **时间复杂度**:$O(n^2)$,因为对于每个数 `i`,计算其阶乘的时间复杂度为 $O(i)$,总的时间复杂度为 $1 + 2 + 3 + \cdots + n = \frac{n(n + 1)}{2}$,即 $O(n^2)$。 - **空间复杂度**:$O(1)$,只使用了常数级的额外空间。 ######[AI问答 | 509点数解答 | 2026-03-28 20:41:08]
- Python 实现球类:精准计算半径、表面积与体积,附输入验证与异常处理!(阿里通义 | 261点数解答 | 2024-11-28 21:19:39)346
- 51 单片机:定时器 0 实现 8 个 LED 循环点亮,附代码及优化建议(字节豆包 | 1193点数解答 | 2024-12-27 15:10:29)316
- C++实现:计算1到不超300的n之间所有奇数之和(DeepSeek | 97点数解答 | 2025-11-01 14:30:12)48
- 轻松计算 1 到 300 内整数间所有奇数和:C++代码实现(字节豆包 | 170点数解答 | 2025-11-01 19:41:22)53
- C++ 实现:计算 1 到 300 内整数中奇数之和(附代码详解与复杂度分析)(字节豆包 | 291点数解答 | 2025-11-01 19:42:26)175
- C++实现:计算m到n间所有奇数之和(含代码详解)(字节豆包 | 151点数解答 | 2025-11-10 13:44:18)92
- C++实现:计算1到n(≤300)间所有奇数和的代码及详细解析 (字节豆包 | 221点数解答 | 2025-11-13 19:39:24)132
- C++实现:计算1到不超300整数间所有奇数和的代码详解(字节豆包 | 328点数解答 | 2025-11-16 11:45:53)60
- C++实现:计算1到n(n≤300)间所有奇数的和(字节豆包 | 134点数解答 | 2025-11-17 12:57:55)61
- C++ 实现:计算 1 到不超 300 的 n 之间所有奇数和及代码详解 (字节豆包 | 323点数解答 | 2025-11-22 18:18:35)55
- 轻松计算 1 到 300 内奇数和:公式推导与 Python 代码实现(DeepSeek | 336点数解答 | 2025-12-05 23:12:35)89
- Python 实现 1 到不超 300 的整数 n 间奇数和计算(DeepSeek | 209点数解答 | 2025-12-07 12:32:17)94