能量波强度总和计算代码优化:从 TLE 到高效求解
### 🔍 问题分析 当前代码在计算第二部分时,使用了两层嵌套循环,时间复杂度为 $O(n^2)$,这会导致在处理大规模数据(如 $N = 5000005$)时超时。我们需要进一步优化这部分的计算,将其复杂度降低到 $O(n)$。 ### 💡 优化思路 对于 $\sum_{k = 3}^{n}a[k]\sum_{j = 1}^{k - 1}\sum_{i = 1}^{j - 1}a[i]$ 这部分,我们可以通过提前计算 $\sum_{j = 1}^{k - 1}\sum_{i = 1}^{j - 1}a[i]$ 的值,避免使用嵌套循环。 设 $s[j]=\sum_{i = 1}^{j - 1}a[i]$,那么 $\sum_{j = 1}^{k - 1}\sum_{i = 1}^{j - 1}a[i]=\sum_{j = 1}^{k - 1}s[j]$。我们可以在一次遍历中计算出 $s[j]$ 和 $\sum_{j = 1}^{k - 1}s[j]$ 的值。 ### 💻 优化后的代码 ```cpp #include <iostream> const int N = 5000005; const int MOD = 1000000007; typedef long long ll; ll a[N]; ll pre_sum[N]; // 前缀和数组 ll s[N]; // s[j] = sum(a[1]...a[j - 1]) ll s_sum[N]; // s_sum[k] = sum(s[1]...s[k - 1]) int main() { int n; std::cin >> n; // 读取能量波强度并计算前缀和 for (int i = 1; i <= n; ++i) { std::cin >> a[i]; pre_sum[i] = (pre_sum[i - 1] + a[i]) % MOD; } ll ans = 0; // 计算第一部分 for (int j = 2; j <= n; ++j) { ll term1 = (a[j] * pre_sum[j - 1] % MOD) * (n - j) % MOD; ans = (ans + term1) % MOD; } // 计算 s[j] 和 s_sum[k] for (int j = 1; j <= n; ++j) { s[j] = pre_sum[j - 1]; s_sum[j] = (s_sum[j - 1] + s[j]) % MOD; } // 计算第二部分 for (int k = 3; k <= n; ++k) { ll term2 = (a[k] * s_sum[k - 1]) % MOD; ans = (ans + term2) % MOD; } std::cout << ans << std::endl; return 0; } ``` ### 📈 复杂度分析 - **时间复杂度**:$O(n)$,通过预处理 $s[j]$ 和 $s\_sum[k]$,避免了嵌套循环,将复杂度降低到线性。 - **空间复杂度**:$O(n)$,主要用于存储前缀和数组、$s$ 数组和 $s\_sum$ 数组。 ######[AI问答 | 803点数解答 | 2026-05-31 19:27:19]
- Python高效求逆序对:归并排序迭代优化与TLE根因分析(阿里通义 | 1754点数解答 | 2026-03-18 17:51:27)43
- 巴黎奥运:中国女排淘汰赛对决土耳其,朱婷成致胜关键!(字节豆包 | 448点数解答 | 2024-08-06 15:59:48)187
- Python逆序对AC终极指南:避开getrandom雷区,迭代归并+安全IO稳过所有大数据(阿里通义 | 1823点数解答 | 2026-03-18 17:53:44)43
- 解决代码 TLE 问题:Python 斐波那契数列优化示例(字节豆包 | 637点数解答 | 2026-04-04 20:09:51)21
- 优化代码解决 TLE 问题:从 $O(n^3)$ 到 $O(n^2)$(字节豆包 | 814点数解答 | 2026-04-04 20:10:30)25
- 解析React 15与Vue 2:从O(n^3)到O(n),Diff算法时间复杂度计算及性能对比 (阿里通义 | 379点数解答 | 2023-11-09 01:49:19)367
- 缜密逻辑,全新无名杀“风餐”技能代码精心打造与深度解析 (字节豆包 | 469点数解答 | 2025-04-05 11:37:06)292
- 精准优化:明确需求,开启高效提升之旅! (字节豆包 | 52点数解答 | 2026-02-09 16:44:46)86
- 代码再升级:优化版“获取dump”代码,多机制保障数据读取与保存(字节豆包 | 734点数解答 | 2026-02-10 01:23:31)96
- 代码深度优化:全面检查异常、灵活读取内存,提升可读性与可维护性(字节豆包 | 959点数解答 | 2026-02-10 01:24:14)70
- C++ 代码实现自定义运算 x@y = x² + y² - xy 及 x@(x+y) 计算(DeepSeek | 215点数解答 | 2025-12-13 15:08:14)111
- C++ 实现根据输入正整数奇偶性计算偶数和或约数和(字节豆包 | 838点数解答 | 2026-02-28 20:23:59)80