给定一个实数序列,设计一个最有效的算法,找到一个总和最大的区间

这个问题是经典的最大子数组和问题,也称为 Kadane 算法。我们可以使用动态规划的方法来高效地解决它。以下是解决方案的 C++ 实现:

复制代码
class Solution {
public:
    vector<int> maxSubArray(vector<double>& nums) {
        if (nums.empty()) return {};
        
        double maxSum = nums[0], currentSum = nums[0];
        int start = 0, end = 0, tempStart = 0;
        
        for (int i = 1; i < nums.size(); i++) {
            if (currentSum + nums[i] > nums[i]) {
                currentSum += nums[i];
            } else {
                currentSum = nums[i];
                tempStart = i;
            }
            
            if (currentSum > maxSum) {
                maxSum = currentSum;
                start = tempStart;
                end = i;
            }
        }
        
        return {start, end, maxSum};
    }
};

这个算法的工作原理如下:

  1. 我们使用两个变量:maxSum 记录到目前为止找到的最大和,currentSum 记录当前子数组的和。
  2. 我们还使用三个索引:startend 记录最大和子数组的起始和结束位置,tempStart 记录当前子数组的起始位置。
  3. 我们从数组的第二个元素开始遍历:
    • 如果将当前元素加入到现有的子数组中会使和增加,我们就将其加入。
    • 否则,我们开始一个新的子数组,从当前元素开始。
  4. 每次我们更新 currentSum 后,我们都会检查它是否大于 maxSum。如果是,我们更新 maxSum 并记录新的起始和结束位置。
  5. 最后,我们返回一个包含最大和子数组的起始位置、结束位置和最大和的向量。

这个算法的时间复杂度是 O(n),其中 n 是数组的长度。它只需要遍历数组一次,因此是非常高效的。空间复杂度是 O(1),因为我们只使用了几个额外的变量,不管输入数组的大小如何。

这个算法可以处理包含正数、负数和零的实数序列。它也可以处理全负数的情况,在这种情况下,它会返回数组中最大的单个元素。

相关推荐
Sirens.几秒前
七大经典排序算法:原理、实现与复杂度分析
java·数据结构·算法·排序算法
wfbcg7 分钟前
每日算法练习:LeetCode 54. 螺旋矩阵 ✅
算法·leetcode·矩阵
黎阳之光10 分钟前
【从虚拟到实体:黎阳之光实时三维重构,开启AI空间智能新纪元
大数据·人工智能·算法·安全·数字孪生
jghhh0116 分钟前
基于主从博弈的主动配电网阻塞管理:MATLAB实现
算法·matlab
小O的算法实验室24 分钟前
2022年IEEE TITS,基于 VRP 优化模型的城市轨道交通智能物流车辆配送路径优化,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
_日拱一卒30 分钟前
LeetCode:206反转链表
算法·leetcode·链表
我不是懒洋洋37 分钟前
【经典题目】链表OJ(轮转数组、返回倒数第k个节点、链表的回文结构)
c语言·开发语言·数据结构·算法·链表·visual studio
SteveSenna37 分钟前
aubo i5+pika realsense+ACT训练完整流程
人工智能·学习·算法·机器人
AC赳赳老秦44 分钟前
OpenClaw对接百度指数:关键词热度分析,精准定位博客创作方向
java·python·算法·百度·dubbo·deepseek·openclaw
551只玄猫1 小时前
Why Financial Data Cannot Be Modeled with “Standard Machine Learning”
算法·机器学习·数学建模·金融·数据科学·英文·金融建模