解决代码WA问题:修改整数溢出问题后的计算代码
### 🐞问题分析 代码WA(Wrong Answer)可能是因为在计算过程中出现了整数溢出的问题。虽然使用了 `long long` 类型,但是在某些中间计算步骤中,可能会超出 `long long` 的表示范围,从而导致结果错误。代码逻辑上本身没有明显错误,主要需要注意取模运算的正确性。 ### ✨修改方案 在进行乘法运算时,要确保每次乘法后都进行取模操作,避免溢出。在累加结果时也需要进行取模操作。 ### 📝修改后的代码 ```cpp #include <iostream> #include <vector> #include <algorithm> const int MOD = 998244353; // 计算所有 f(l, r) 的和 long long calculateSum(const std::vector<int>& a, const std::vector<int>& b) { int n = a.size(); std::vector<long long> c(n); // 计算 c[i] = a[i] * b[i] for (int i = 0; i < n; ++i) { // 确保乘法结果取模 c[i] = ((long long)a[i] * b[i]) % MOD; } long long sum = 0; // 计算每个 c[i] 在所有 f(l, r) 中出现的次数 for (int i = 0; i < n; ++i) { // 计算 c[i] 出现的次数 long long count = ((long long)(i + 1) * (n - i)) % MOD; // 确保乘法和累加结果取模 sum = (sum + (c[i] * count) % MOD) % 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; } ``` ### 🔍代码解释 - 在计算 `c[i]` 时,将 `a[i]` 和 `b[i]` 转换为 `long long` 类型并进行乘法运算,然后对结果取模,避免溢出。 - 在计算 `count` 时,同样将 `i + 1` 和 `n - i` 转换为 `long long` 类型并进行乘法运算,然后对结果取模。 - 在累加 `sum` 时,先将 `c[i]` 和 `count` 相乘并取模,再将结果累加到 `sum` 中,最后对 `sum` 取模。 ######[AI问答 | 749点数解答 | 2026-05-10 16:20:03]
- 判断超级幸运数:满足“纯4/7数位”或“4/7总个数为4或7”的整数计数(阿里通义 | 965点数解答 | 2026-03-13 12:15:06)53
- 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 语言:按特定顺序读入并输出浮点数、整数和字符(字节豆包 | 106点数解答 | 2024-09-26 00:32:40)340
- C语言:按序读入浮点数、整数、字符并按新顺序输出,附代码实现 (字节豆包 | 108点数解答 | 2024-09-30 22:54:08)353
- C语言:按特定顺序读入并输出浮点数、整数和字符,精确控制小数位(字节豆包 | 155点数解答 | 2024-10-08 22:06:18)348
- C++与Python:按特定顺序输入输出数据并保留浮点数两位小数的实现(字节豆包 | 168点数解答 | 2024-10-08 22:07:03)352
- C语言:按特定顺序读入再输出,含浮点数精确格式处理(字节豆包 | 105点数解答 | 2024-10-08 22:07:29)361
- C++ 混合类型数据格式化输入输出:按指定顺序输出并保留两位小数(字节豆包 | 187点数解答 | 2024-10-16 14:31:08)406
- C语言:实现混合类型数据格式化输入输出,代码超简单!(字节豆包 | 159点数解答 | 2024-10-16 14:32:18)397
- C语言:按特定格式输入并格式化输出整数、实数和字符(字节豆包 | 103点数解答 | 2024-10-24 11:12:53)426
- Java 实现:从点类到圆类,计算圆心坐标(50,30)、半径 4 的圆周长与面积(字节豆包 | 246点数解答 | 2024-11-11 16:36:30)359