C++最大子数组和问题及Kadane算法实现
这个问题是一个典型的 **最大子数组和** 问题(Kadane 算法)。 ```cpp #include <iostream> #include <vector> #include <algorithm> using namespace std; int maxSubarraySum(const vector<int>& nums) { int currentSum = 0; int maxSum = nums[0]; // 初始化为第一个元素的值 for (int num : nums) { currentSum = max(num, currentSum + num); maxSum = max(maxSum, currentSum); } return maxSum; } int main() { vector<int> gains = {1, -2, 3, 5, -1, 2}; // 示例输入 int result = maxSubarraySum(gains); cout << "最大总增益为: " << result << endl; return 0; } ``` 这段代码使用 Kadane 算法在线性时间内解决问题。它遍历数组,维护两个关键变量: - `currentSum`:以当前位置结尾的最大子数组和 - `maxSum`:全局最大子数组和 每个位置选择“从当前元素重新开始”或者“延续之前的子数组”中较大的一个。初始将 `maxSum` 设为第一个元素的值,确保数组全为负数时也能正确返回最大值。 ######[AI问答 | 289点数解答 | 2026-05-16 22:07:13]
- Python 实现球类:精准计算半径、表面积与体积,附输入验证与异常处理!(阿里通义 | 261点数解答 | 2024-11-28 21:19:39)388
- C++实现计算最少添加数字次数以匹配两个数组元素(字节豆包 | 714点数解答 | 2026-03-08 19:44:54)35
- 51 单片机:定时器 0 实现 8 个 LED 循环点亮,附代码及优化建议(字节豆包 | 1193点数解答 | 2024-12-27 15:10:29)358
- Python切片操作巧解经典算法:二维数组90°旋转(阿里通义 | 205点数解答 | 2023-10-31 11:05:29)354
- 揭秘iOS开发:常用算法大集合,提升应用性能与体验!(阿里通义 | 246点数解答 | 2023-11-08 00:43:08)305
- 深入解析:Vue2.x与Vuex3.x渲染器的Diff算法奥秘(阿里通义 | 222点数解答 | 2023-11-09 01:35:41)382
- 突破 long 范围限制:用 BigInteger 类实现超大数字竖式乘法运算( | 555点数解答 | 2024-03-17 10:56:49)383
- 超范围数字乘法:字符串转数组+模拟竖式运算的实现攻略( | 377点数解答 | 2024-03-17 10:58:21)381
- Java 实现:突破 long 范围限制,模拟竖式运算处理大数字乘法( | 14点数解答 | 2024-03-17 10:58:39)358
- Java实现:突破long范围限制,模拟人工竖式运算大数字乘法( | 1022点数解答 | 2024-03-17 10:59:43)365
- C语言实现:从键盘输入正整数,轻松判断是否为素数(百度文心 | 576点数解答 | 2024-11-10 19:38:17)363
- C 语言:用欧几里得算法从键盘输入两数求最大公约数(附代码及注意点)(字节豆包 | 277点数解答 | 2024-12-31 10:47:11)308