优化代码解决超时问题:计算数组 f(l, r) 最小和
💡原代码之所以会超时(TLE),是因为使用了全排列的方法,其时间复杂度达到了 $O(n! \times n^3)$ ,当 $n$ 较大时,这个复杂度会导致程序运行时间过长。我们可以采用贪心算法来优化,将数组 `a` 按从小到大排序,数组 `b` 按从大到小排序,然后计算一次 `f(l, r)` 的和,这样时间复杂度可以优化到 $O(n^2)$ 。 以下是优化后的代码: ```cpp #include <iostream> #include <vector> #include <algorithm> const int MOD = 998244353; // 计算 f(l, r) 函数 long long f(const std::vector<int>& a, const std::vector<int>& b, int l, int r) { long long res = 0; for (int i = l; i <= r; ++i) { res = (res + (long long)a[i] * b[i]) % MOD; } return res; } // 计算所有 f(l, r) 的和 long long calculateSum(const std::vector<int>& a, const std::vector<int>& b) { int n = a.size(); long long sum = 0; for (int l = 0; l < n; ++l) { for (int r = l; r < n; ++r) { sum = (sum + f(a, b, l, r)) % MOD; } } return sum; } int main() { int n; std::cin >> n; std::vector<int> a(n), b(n); for (int i = 0; i < n; ++i) { std::cin >> a[i]; } for (int i = 0; i < n; ++i) { std::cin >> b[i]; } // 对 a 数组从小到大排序 std::sort(a.begin(), a.end()); // 对 b 数组从大到小排序 std::sort(b.begin(), b.end(), std::greater<int>()); long long minSum = calculateSum(a, b); std::cout << minSum << std::endl; return 0; } ``` ### 代码解释: 1. **输入处理**:读取数组 `a` 和 `b` 的长度 `n` ,并分别读取数组 `a` 和 `b` 的元素。 2. **排序操作**:将数组 `a` 按从小到大排序,数组 `b` 按从大到小排序。这样做的原因是,为了使 `f(l, r)` 的和最小,我们希望较小的 `a[i]` 与较大的 `b[i]` 相乘。 3. **计算和**:调用 `calculateSum` 函数计算排序后数组 `a` 和 `b` 的所有 `f(l, r)` 的和。 4. **输出结果**:输出计算得到的最小和。 ### 复杂度分析: - **时间复杂度**:排序的时间复杂度为 $O(n log n)$ ,计算 `f(l, r)` 的和的时间复杂度为 $O(n^2)$ ,因此总的时间复杂度为 $O(n^2)$ 。 - **空间复杂度**:主要使用了两个长度为 `n` 的数组,因此空间复杂度为 $O(n)$ 。 ######[AI问答 | 821点数解答 | 2026-05-10 16:15:59]
- C3期末:精准求解 3 - 20 范围内数列第 k 项值及注意要点(字节豆包 | 242点数解答 | 2025-06-15 11:26:19)165
- C++求解:查找3 - 20项数列第k项值及注意要点(字节豆包 | 325点数解答 | 2025-06-15 11:27:11)185
- C++实现计算最少添加数字次数以匹配两个数组元素(字节豆包 | 714点数解答 | 2026-03-08 19:44:54)33
- 旅行售货员问题:详细步骤剖析与贪心算法Python代码实现(字节豆包 | 444点数解答 | 2024-12-17 03:32:59)297
- Dev C++ 实现旅行售货员问题:最小路程路线代码与详细解析 (字节豆包 | 448点数解答 | 2024-12-17 03:33:42)195
- C++ 求解 P1020 小核桃与删除字符串问题:双指针与枚举策略 (字节豆包 | 330点数解答 | 2026-02-07 18:40:10)41
- 解析React 15与Vue 2:从O(n^3)到O(n),Diff算法时间复杂度计算及性能对比 (阿里通义 | 379点数解答 | 2023-11-09 01:49:19)357
- 缜密逻辑,全新无名杀“风餐”技能代码精心打造与深度解析 (字节豆包 | 469点数解答 | 2025-04-05 11:37:06)274
- 精准优化:明确需求,开启高效提升之旅! (字节豆包 | 52点数解答 | 2026-02-09 16:44:46)64
- 代码再升级:优化版“获取dump”代码,多机制保障数据读取与保存(字节豆包 | 734点数解答 | 2026-02-10 01:23:31)86
- 代码深度优化:全面检查异常、灵活读取内存,提升可读性与可维护性(字节豆包 | 959点数解答 | 2026-02-10 01:24:14)58
- C++ 代码实现自定义运算 x@y = x² + y² - xy 及 x@(x+y) 计算(DeepSeek | 215点数解答 | 2025-12-13 15:08:14)101