hud 1003 Max Snm(最小前缀和、尺取法)

题意:在o(n)时间内,求最大连续的子序列的和最大,及其起点和终点。

数据:输入以及输出

 方法一:一边读取数据一边维护最小前缀和S[i],然后不断更新ans,ans=max(ans,s[i]-s[k]),以及初始位置st,en;

代码:

#include<iostream>
#include<cstdio>
using namespace std;
const int maxn=100010;
int s[maxn];
int main()
{
    int cun=1;
    int t;
    cin>>t;
    while(t--)
    {
        int n;
        cin>>n;
        int k=0;
        int st,en;
        int num;
        int a[maxn];
        s[0]=0;
        int ans=-1001;
        for(int i=1;i<=n;i++)
        {
            scanf("%d",&num);
            s[i]=s[i-1]+num;
            if(s[i]-s[k]>ans)
            {
                ans=s[i]-s[k];
                en=i;
                st=k+1;
            }
            if(s[i]<s[k]){
                k=i;
            }
        }
        printf("Case %d:\n%d %d %d\n",cun,ans,st,en);
        cun++;
    }
    return 0;
}

代码下的运行过程分析(第一组数据):

is[i]ks[k]anssten
0000-100100
1600611
2500611
310001013
414001414
57001414

 

再分析一组数据:5  5 -7 4 6 -1     输出结果为:10 3 4

is[i]ks[k]anssten
0000-100100
1500511
2-22-2511
322-2511
482-21034
572-21034

从这两组数据分析中并结合实际可以分析出s[k]是用来调和新的可能最大的连续子序列,由于s[i]是由s[i-1]+a递推过来的,所以当s[i]<s[k]时k=i;s[i]-s[k]可以还原由于递推过来重新开始时最初那个数据的缺失,例如,第二次数据分析中i=3时a原本是4的,但却由于s[i]=s[i-1]+a变成了2,所以再执行s[i]-s[k]把i=3的a从2还原成4,s[k]的作用就在于此。


 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值