浅析连续子向量,子数组和(一维,二维)问题

本文深入探讨了一维和二维数组中连续子数组和的问题,包括最大连续子向量和、子向量和接近于0、收费站问题、区间赋值问题以及二维连续子数组和的解题策略,涉及分治、动态规划等算法思想。
摘要由CSDN通过智能技术生成

浅析连续子向量,子数组和(一维,二维)问题

 9月 16 2014 更新日期:9月 16 2014

文章目录
  1. 1. 最大连续子向量和
    1. 1.0.1. 问题描述:

最大连续子向量和

问题描述:
输入是具有n个浮点数的向量x,输出这个向量的任何连续子向量中的最大和。

简单分析:子向量可以是一个空向量,空向量的和为0;如果向量的所有元素都是负数,最大子向量和就是0;

1 简单分析后,对于这个问题,我们立马能向想到的就是暴力算法,对所有0<=i<=j<n的整数对进行迭代。对每个整数对(i,j),程序都要计算x[i…j]的总和,并判断其是否大于当前的最大总和。

解法1:简单粗暴型
int res=0; //答案
for(int i= 0 ; i<n;i++)
    for(int j=i;j<n;j++)
    {
        sum=0
        for(int k=i;k<=j;k++) 
            sum+=x[k]
        res=max(res,sum)    
    }

2 怎么看,上面的算法都是简单粗暴型,O(n^3)的时间复杂度实在不敢恭维,数据量一大,时间上实在不能容忍。那么有没有稍微优雅一点的?我们发现后面的部分有重复计算的,那么我们如何节省它~~一种就是从i开始往前加的时候,每次都记录下来。直接看代码:

解法2int res=0;  //答案
for(int i=0;i<n;i++)
{
    int sum=0;  
    for(int j=i;j<n;j++)
    {
        
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值