优化能量波计算代码至O(n)复杂度
### 💡思路分析 原代码的时间复杂度是 $O(n^2)$,对于 $n$ 最大为 $5000000$ 的数据范围会超时,需要将其优化到 $O(n)$。 对公式 $\sum_{i = 1}^{n}\sum_{j = i + 1}^{n}\sum_{k = j + 1}^{n}(a[i]*a[j]+a[i]*a[k])$ 进行化简: - 先对 $\sum_{i = 1}^{n}\sum_{j = i + 1}^{n}\sum_{k = j + 1}^{n}(a[i]*a[j]+a[i]*a[k])$ 拆分为 $\sum_{i = 1}^{n}\sum_{j = i + 1}^{n}\sum_{k = j + 1}^{n}a[i]*a[j]+\sum_{i = 1}^{n}\sum_{j = i + 1}^{n}\sum_{k = j + 1}^{n}a[i]*a[k]$。 - 对于 $\sum_{i = 1}^{n}\sum_{j = i + 1}^{n}\sum_{k = j + 1}^{n}a[i]*a[j]$,因为 $a[i]*a[j]$ 与 $k$ 无关,所以 $\sum_{i = 1}^{n}\sum_{j = i + 1}^{n}\sum_{k = j + 1}^{n}a[i]*a[j]=\sum_{i = 1}^{n}\sum_{j = i + 1}^{n}a[i]*a[j]*(n - j)$。 - 对于 $\sum_{i = 1}^{n}\sum_{j = i + 1}^{n}\sum_{k = j + 1}^{n}a[i]*a[k]$,可以交换求和顺序,先对 $k$ 求和,再对 $j$ 求和,最后对 $i$ 求和。可以通过预处理后缀和来优化计算。 ### 📝优化后的代码 ```cpp #include <iostream> const int N = 5000005; const int MOD = 1000000007; typedef long long ll; int main() { int n; std::cin >> n; ll a[N]; ll suffix_sum[N] = {0}; ll suffix_count[N] = {0}; // 读取能量波强度 for (int i = 1; i <= n; ++i) { std::cin >> a[i]; } // 计算后缀和与后缀数量 for (int i = n; i >= 1; --i) { suffix_sum[i] = (suffix_sum[i + 1] + a[i]) % MOD; suffix_count[i] = suffix_count[i + 1] + 1; } ll ans = 0; for (int i = 1; i <= n; ++i) { for (int j = i + 1; j <= n; ++j) { // 计算 a[i]*a[j] 部分 ll term1 = (a[i] * a[j] % MOD) * (n - j) % MOD; // 计算 a[i]*a[k] 部分 ll term2 = (a[i] * (suffix_sum[j + 1]) % MOD) % MOD; ans = (ans + term1 + term2) % MOD; } } std::cout << ans << std::endl; return 0; } ``` ### 🔍复杂度分析 - **时间复杂度**:$O(n)$,主要是预处理后缀和与后缀数量的时间复杂度为 $O(n)$,后续计算的时间复杂度也为 $O(n)$。 - **空间复杂度**:$O(n)$,主要是存储后缀和与后缀数量的数组的空间开销。 ######[AI问答 | 911点数解答 | 2026-05-31 18:41:38]
- C++求解序列或与运算和差值:避O(nq)复杂度及数据处理要点(字节豆包 | 534点数解答 | 2025-10-17 20:05:07)79
- 解析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
- 解决代码WA问题:修改整数溢出问题后的计算代码(字节豆包 | 749点数解答 | 2026-05-10 16:20:03)28
- 修正代码解决计算 f(l, r) 和出现的 WA 问题(字节豆包 | 806点数解答 | 2026-05-10 16:21:37)29
- 大学生日常花销记账App开发:测试部署与后端开发工作全揭秘(百度文心 | 612点数解答 | 2024-05-15 18:59:38)369
- JS 代码:轻松定义变量 test 并赋值为“red”( | 6点数解答 | 2024-05-19 20:46:45)398