高效算法:计算1到n所有数的因子总和(C++实现)
```cpp #include <iostream> using namespace std; int main() { int n; cin >> n; long long totalSum = 0; // 使用 long long 防止溢出 // 方法:直接计算每个数对总和的贡献 // 对于因子k,它在1到n之间出现的次数是 n/k for (int k = 1; k <= n; k++) { totalSum += (n / k) * k; // k作为因子出现的总次数乘以k } cout << totalSum << endl; return 0; } ``` ### 🔢 解题思路说明 **核心思想**:不逐个计算每个数的因子,而是统计每个数字作为因子出现的次数。 **数学原理**: - 对于任意因子 `k`(1 ≤ k ≤ n),它在区间 [1, n] 中作为因子出现的次数为 `n / k`(向下取整) - 每个 `k` 对总和的贡献为:`k × (n / k)` **示例验证**(n=5): | 因子k | 出现次数(n/k) | 贡献值 | |-------|--------------|--------| | 1 | 5 | 5×1=5 | | 2 | 2 | 2×2=4 | | 3 | 1 | 3×1=3 | | 4 | 1 | 4×1=4 | | 5 | 1 | 5×1=5 | | 总和 | | 21 | **时间复杂度**:O(n),空间复杂度:O(1) ######[AI问答 | 394点数解答 | 2026-06-07 19:19:11]
- 巴黎奥运:中国女排淘汰赛对决土耳其,朱婷成致胜关键!(字节豆包 | 448点数解答 | 2024-08-06 15:59:48)189
- Python 实现球类:精准计算半径、表面积与体积,附输入验证与异常处理!(阿里通义 | 261点数解答 | 2024-11-28 21:19:39)415
- 51 单片机:定时器 0 实现 8 个 LED 循环点亮,附代码及优化建议(字节豆包 | 1193点数解答 | 2024-12-27 15:10:29)376
- C++ 代码实现自定义运算 x@y = x² + y² - xy 及 x@(x+y) 计算(DeepSeek | 215点数解答 | 2025-12-13 15:08:14)112
- C++ 实现根据输入正整数奇偶性计算偶数和或约数和(字节豆包 | 838点数解答 | 2026-02-28 20:23:59)85
- 解决代码WA问题:修改整数溢出问题后的计算代码(字节豆包 | 749点数解答 | 2026-05-10 16:20:03)31
- 修正代码解决计算 f(l, r) 和出现的 WA 问题(字节豆包 | 806点数解答 | 2026-05-10 16:21:37)32
- Python切片操作巧解经典算法:二维数组90°旋转(阿里通义 | 205点数解答 | 2023-10-31 11:05:29)359
- 揭秘iOS开发:常用算法大集合,提升应用性能与体验!(阿里通义 | 246点数解答 | 2023-11-08 00:43:08)309
- 深入解析:Vue2.x与Vuex3.x渲染器的Diff算法奥秘(阿里通义 | 222点数解答 | 2023-11-09 01:35:41)388
- 突破 long 范围限制:用 BigInteger 类实现超大数字竖式乘法运算( | 555点数解答 | 2024-03-17 10:56:49)387
- 超范围数字乘法:字符串转数组+模拟竖式运算的实现攻略( | 377点数解答 | 2024-03-17 10:58:21)383