优化能量波强度计算代码,避免超时问题
### 🚀 问题分析 当前代码虽然通过后缀和进行了一定优化,但仍然使用了两层嵌套循环,时间复杂度为 $O(n^2)$。对于 $N = 5000005$ 这样大规模的数据,$O(n^2)$ 的时间复杂度会导致超时(TLE),需要进一步优化到 $O(n)$ 的复杂度。 ### 💡 优化思路 我们对原式 $\sum_{i = 1}^{n}\sum_{j = i + 1}^{n}\sum_{k = j + 1}^{n}(a[i]*a[j]+a[i]*a[k])$ 进行更深入的数学推导和化简。 将原式拆分为两部分: 1. 先看 $\sum_{i = 1}^{n}\sum_{j = i + 1}^{n}\sum_{k = j + 1}^{n}a[i]a[j]$: - 交换求和顺序,先对 $j$ 求和,再对 $i$ 求和。对于固定的 $j$,$i$ 的取值范围是 $1$ 到 $j - 1$。 - $\sum_{i = 1}^{n}\sum_{j = i + 1}^{n}\sum_{k = j + 1}^{n}a[i]a[j]=\sum_{j = 2}^{n}a[j]\sum_{i = 1}^{j - 1}a[i]\sum_{k = j + 1}^{n}1$。 - 其中 $\sum_{k = j + 1}^{n}1=n - j$,我们可以预处理前缀和 $pre\_sum$ 来快速计算 $\sum_{i = 1}^{j - 1}a[i]$。 2. 再看 $\sum_{i = 1}^{n}\sum_{j = i + 1}^{n}\sum_{k = j + 1}^{n}a[i]a[k]$: - 同样交换求和顺序,对于固定的 $k$,$j$ 的取值范围是 $1$ 到 $k - 1$,$i$ 的取值范围是 $1$ 到 $j - 1$。 - $\sum_{i = 1}^{n}\sum_{j = i + 1}^{n}\sum_{k = j + 1}^{n}a[i]a[k]=\sum_{k = 3}^{n}a[k]\sum_{j = 1}^{k - 1}\sum_{i = 1}^{j - 1}a[i]$。 - 可以通过预处理前缀和来优化计算。 ### 💻 优化后的代码 ```cpp #include <iostream> const int N = 5000005; const int MOD = 1000000007; typedef long long ll; ll a[N]; ll pre_sum[N]; // 前缀和数组 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; } // 计算第二部分 for (int k = 3; k <= n; ++k) { for (int j = 1; j < k; ++j) { ll term2 = (a[k] * pre_sum[j - 1]) % MOD; ans = (ans + term2) % MOD; } } std::cout << ans << std::endl; return 0; } ``` ### 📈 复杂度分析 - **时间复杂度**:$O(n)$,通过预处理前缀和,避免了多层嵌套循环,减少了不必要的计算。 - **空间复杂度**:$O(n)$,主要用于存储前缀和数组。 ######[AI问答 | 991点数解答 | 2026-05-31 19:26: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
- 解决代码WA问题:修改整数溢出问题后的计算代码(字节豆包 | 749点数解答 | 2026-05-10 16:20:03)28
- 修正代码解决计算 f(l, r) 和出现的 WA 问题(字节豆包 | 806点数解答 | 2026-05-10 16:21:37)29
- 浙闽“板凳龙”舞龙队 300 秒螺线盘入:位置与速度全揭秘(阿里通义 | 886点数解答 | 2024-09-07 10:31:31)666
- 浙闽“板凳龙”舞龙队 300 秒位置与速度数学模型揭秘(GPT | 565点数解答 | 2024-09-07 10:32:56)558
- 223节板凳龙沿等距螺线盘入:300秒内位置与速度的数学揭秘 (讯飞星火 | 443点数解答 | 2024-09-07 10:34:10)409