首页 > 编程语言 >给定一个实数序列,设计一个最有效的算法,找到一个总和最大的区间

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

时间:2024-06-23 22:56:50浏览次数:31  
标签:currentSum nums 实数 tempStart start 算法 给定 数组 maxSum

这个问题是经典的最大子数组和问题,也称为 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),因为我们只使用了几个额外的变量,不管输入数组的大小如何。

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

标签:currentSum,nums,实数,tempStart,start,算法,给定,数组,maxSum
From: https://blog.csdn.net/m0_61862494/article/details/139908193

相关文章

  • 数组和链表-《算法图解》学习
    内存工作原理需要将数据存储到内存时,你请求计算机提供存储空间,计算机给你一个存储地址。需要存储多项数据时,有两种基本方式——数组和链表。但它们并非都适用于所有的情形,因此知道它们的差别很重要。接下来介绍数组和链表以及它们的优缺点。 ==============tobeconntinued......
  • 【TWVRP】遗传算法求解带时间窗的载重约束外卖配送车辆路径规划问题【含Matlab源码 14
    ......
  • Rabin Karp 算法
    RabinKarp算法RabinKarp算法,简称RK算法,是由MichaelOserRabin和RichardManningKarp在1987年提出的字符串搜索算法。该算法主要用于在文本中搜索单个模式串的位置,其基于哈希函数的原理,将字符串和模式都映射为一个整数值,并通过比较这些整数值来确定它们是否匹......
  • 目标检测经典算法及其应用
    目标检测是计算机视觉领域中的一项核心技术,它旨在让计算机能够像人眼一样识别和定位图像或视频中的物体。具体来说,目标检测不仅需要识别出图像或视频中有哪些对象,还要确定它们在图像或视频中的位置(通常以边界框的形式表示)以及它们的类别。目标检测的基本框架通常包括三个主要......
  • 算法设计与分析复习总结(一)
    算法分析与设计复习总结第一章算法概述算法与程序算法的四条性质程序的特点算法复杂度分析时间复杂度关于拉斯维加斯算法工作原理保证正确性的原因例子:快速选择算法(Quickselect)形式化证明结论计算模型基本计算模型NP完全性理论约化的概念几类问题的韦恩关系图P问题(P......
  • 算法训练营第六十七天 | 卡码网110 字符串接龙、卡码网105 有向图的完全可达性、卡码
    卡码网110字符串接龙这题一开始用的邻接表+dfs,不幸超时#include<iostream>#include<list>#include<string>#include<vector>usingnamespacestd;intminLen=501;boolcount(stringa,stringb){intnum=0;for(inti=0;i<a.lengt......
  • 基础算法(1)
    文章目录数学函数math.h(cmath)头文件float.h头文件拆位拆位进阶奇偶判断质数判断在c++中,会涉及到一些算法,例如递归、递推、动态规划(DP)、深搜(DFS)、广搜(BFS)……今天我们要说的是一些简单的算法数学函数math.h(cmath)头文件选择任意一个头文件#include<cmath>//仅......
  • 给定一字符串,从中提取最大的数字。
    给定一字符串,包含数字、小写字母、正负号、小数点,从中提取最大的数字。/***给定一字符串,包含数字、小写字母、正负号、小数点,从中提取最大的数字*abc56dfg+78ddd-89aa89.3ggg*/publicclassMain{publicstaticvoidmain(String[]args){System.out.p......
  • 【Matlab】LSTM长短期记忆神经网络分类算法(附代码)
      资源下载: https://download.csdn.net/download/vvoennvv/89465998 分类算法资源合集:https://download.csdn.net/download/vvoennvv/89466519 目录MatlabSVM支持向量机分类算法MatlabRF随机森林分类算法MatlabRBF径向基神经网络分类算法MatlabPSO-BP基于粒子......
  • [算法篇] 简单讲讲一维前缀和与差分
    前缀和:先给定义:指某序列的前n项和是不是与我们高中所学的数列求和类似?给出用途: 如我们于一组长度为n的整数序列中询问m次,每次询问中输出区间[l,r]中数之和倘若我们先不使用前缀和,预测一下思路将会是:m次询问中,每一次都求和数组[l,r]时间复杂度为O(n),思路很简单但若m非常大则将......