乘积求和问题的优化解法:从TLE到高效计算
我们可以对原问题的计算方式进行优化,避免使用双重循环,从而降低时间复杂度。 原问题要求计算 $S = a_1\cdot a_2 + a_1\cdot a_3+\cdots + a_1\cdot a_n + a_2\cdot a_3+\cdots + a_{n - 2}\cdot a_{n - 1}+a_{n - 2}\cdot a_n + a_{n - 1}\cdot a_n$。 我们知道 $(a_1 + a_2+\cdots + a_n)^2=a_1^2 + a_2^2+\cdots + a_n^2+2(a_1\cdot a_2 + a_1\cdot a_3+\cdots + a_1\cdot a_n + a_2\cdot a_3+\cdots + a_{n - 2}\cdot a_{n - 1}+a_{n - 2}\cdot a_n + a_{n - 1}\cdot a_n)$。 那么 $S=\frac{(\sum_{i = 1}^{n}a_i)^2-\sum_{i = 1}^{n}a_i^2}{2}$。 以下是优化后的Python代码: ```python n = int(input()) # 读取输入的n个整数 nums = list(map(int, input().split())) # 计算所有数的和 total_sum = sum(nums) # 计算所有数的平方和 square_sum = sum([i ** 2 for i in nums]) # 按照公式计算结果 result = (total_sum ** 2 - square_sum) // 2 print(result) ``` ### 代码解释 1. **输入处理**:首先读取整数`n`,接着读取`n`个整数并存储在列表`nums`中。 2. **计算总和与平方和**:使用`sum`函数分别计算所有数的和`total_sum`以及所有数的平方和`square_sum`。 3. **计算最终结果**:根据推导的公式 $S=\frac{(\sum_{i = 1}^{n}a_i)^2-\sum_{i = 1}^{n}a_i^2}{2}$ 计算最终结果。 4. **输出结果**:将计算得到的结果输出。 ### 复杂度分析 - **时间复杂度**:$O(n)$,因为只需要对数组进行一次遍历。 - **空间复杂度**:$O(n)$,主要用于存储输入的整数列表。 ######[AI问答 | 566点数解答 | 2026-05-10 16:02:05]
- Python高效求逆序对:归并排序迭代优化与TLE根因分析(阿里通义 | 1754点数解答 | 2026-03-18 17:51:27)43
- 巴黎奥运:中国女排淘汰赛对决土耳其,朱婷成致胜关键!(字节豆包 | 448点数解答 | 2024-08-06 15:59:48)182
- Python 实现:根据入职年限和销售业绩精准计算职工奖金并列表输出(字节豆包 | 215点数解答 | 2024-11-07 01:01:17)117
- Python逆序对AC终极指南:避开getrandom雷区,迭代归并+安全IO稳过所有大数据(阿里通义 | 1823点数解答 | 2026-03-18 17:53:44)41
- 解决代码 TLE 问题:Python 斐波那契数列优化示例(字节豆包 | 637点数解答 | 2026-04-04 20:09:51)20
- 优化代码解决 TLE 问题:从 $O(n^3)$ 到 $O(n^2)$(字节豆包 | 814点数解答 | 2026-04-04 20:10:30)21
- 解析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)88
- 代码深度优化:全面检查异常、灵活读取内存,提升可读性与可维护性(字节豆包 | 959点数解答 | 2026-02-10 01:24:14)59
- C++ 代码实现自定义运算 x@y = x² + y² - xy 及 x@(x+y) 计算(DeepSeek | 215点数解答 | 2025-12-13 15:08:14)101