基础DP

来源:互联网 发布:叶子正品软件 编辑:程序博客网 时间:2024/06/01 09:17

1050 循环数组最大子段和

N个整数组成的循环序列a[1],a[2],a[3],…,a[n],求该序列如a[i]+a[i+1]+…+a[j]的连续的子段和的最大值(循环序列是指n个数围成一个圈,因此需要考虑a[n-1],a[n],a[1],a[2]这样的序列)。当所给的整数均为负数时和为0。
例如:-2,11,-4,13,-5,-2,和最大的子段为:11,-4,13。和为20。
Input
第1行:整数序列的长度N(2 <= N <= 50000)第2 - N+1行:N个整数 (-10^9 <= S[i] <= 10^9)
Output
输出循环数组的最大子段和。
Input示例
6-211-413-5-2
Output示例
20

  本题与普通的最大子段和问题不同的是,最大子段和可以是首尾相接的情况,即可以循环。

  那么这个题目的最大子段和有两种情况

    (1)正常数组中间的某一段和最大。这个可以通过普通的最大子段和问题求出。

    (2)此数组首尾相接的某一段和最大。这种情况是由于数组中间某段和为负值,且绝对值很大导致的,那么我

        们只需要把中间的和为负值且绝对值最大的这一段序列求出,(负值最大的子段取反之后就是就是正值最大的子段)

        用总的和减去它就行了。


     原数组的所有元素和为sum。先对原数组求最大子段和,得到ans1,然后把数组中所有元素符号取反,再求

     最子段和,得到 ans2=sum-∑itojai = sum+itoj(-ai),那么最终答案就是max(ans1, ans + ans2)


code :

#include <iostream>#include <stdio.h>#include <string.h>#define LL long longusing namespace std;const int ma=5e4+5;LL a[ma],dp[ma];LL work(int n){     LL ans=0,tp=0;     for(int i=1;i<=n;++i)     {         if(tp<0) tp=a[i];         else tp+=a[i];         ans=max(ans,tp);     }     return ans;}int main(){    int n;    while(scanf("%d",&n)!=EOF)    {        LL ans=0,ans1=0,ans2=0,sum=0;        for(int i=1;i<=n;++i)        {            scanf("%lld",&a[i]);            sum+=a[i];        }        ans1=work(n);        for(int i=1;i<=n;++i)            a[i]=-a[i];        ans2=work(n);        ans=max(ans1,sum+ans2);         printf("%lld\n",ans);    }    return 0;}




原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 宝宝眼睛流泪还有眼屎怎么办? 新生儿眼睛上火眼屎多怎么办 铁耳屎在最里面怎么办 婴儿鼻屎特别深怎么办 鼻子干呼吸就疼怎么办 儿童鼻子里总有好多鼻屎怎么办 小孩鼻子里有鼻屎呼吸不通怎么办 鼻子不通通气鼻屎粘在鼻子怎么办 鼻子里面干燥长鼻屎怎么办 鼻孔里干的难受怎么办 每天有很多鼻屎怎么办 鼻子里面干的疼怎么办 婴儿鼻屎堵住了怎么办 婴儿有很多鼻屎怎么办 隆鼻7天好多鼻屎怎么办 隆鼻第五天好多鼻屎怎么办 小孩鼻屎堵住了怎么办 风寒感冒流清鼻涕怎么办 流清鼻涕吐黄痰不发烧怎么办 宝宝流黄鼻涕发烧怎么办 感冒了浓鼻涕多怎么办 感冒流浓鼻涕怎么办速效办法 孩子一直流清水鼻涕怎么办 宝宝鼻子呼噜呼噜响怎么办 鼻涕往嗓子里流怎么办 咳嗽痰多鼻涕多怎么办 没感冒嗓子痰多鼻涕怎么办 孩子感冒后鼻涕特别多怎么办 经常有鼻涕怎么办才好 怀孕后鼻涕痰多怎么办 鼻炎有鼻涕痰多怎么办 宝宝咳嗽痰多鼻涕多怎么办 宝宝两岁清鼻涕咳嗽痰多怎么办 喉咙咸咸的有痰怎么办 宝宝咳嗽鼻塞喉咙有痰怎么办 绝地求生刺激战场射击键误触怎么办 在皮卡堂卡的游泳了怎么办 假如遇到老赖没能力还钱怎么办 服刑人拒不执行伤害赔偿怎么办? 面对当前严峻形势作为军人怎么办 想起诉不知道对方地址怎么办