码迷,mamicode.com
首页 > 其他好文 > 详细

[HDU 1003] Max Sum

时间:2016-06-05 16:57:23      阅读:135      评论:0      收藏:0      [点我收藏+]

标签:

一道很老的题目了,题解也很多,我比较智障,以前勉强做出来了,有一天看见了,又做不出来了。写一篇题解稍微强化下。

题目大意:

给N个数 1~1000000 ,有正有负,判断里面连续最长的和是多少,并且是从第几个加到第几个数。

如果题目中的N小一点,比如只有1000或者10000的话,很容易就可以用前缀和的暴力平方复杂度过去。然而,如果N比较大的话,像这题。就只能用O(n)的优化的算法。也就是只扫一遍。

首先思考,比如我的数列是 5 6 -1 3 4 这样,要求和最大。那么我们很明显,前两个数字会被算进去,因为都是正数,加上去一定更大。然后遇到了负数-1,这个时候,前面的数字和 sum 到底要不要加上-1,似乎要关系到后面的数字的情况,比较麻烦。实际上细细的思考以后,发现如果遇到了一个数,情况只有两种:

1. 前面的和,加上了当前的数字,会得到比只有当前数字更好的情况。

2. 当前数字不加上前面的sum,sum等于当前数字,结果更加大。

 

如果碰到了第二种情况,我们要更新记录起点终点,也就是说,前面的和没有我们现在考虑的大。

如果碰到第一种情况,我们只需要加上当前的数字,也就是说结果只能更加好。

主体情况就是:

 开始时 :

 ans = a[1]; ans_begin = ans_end = temp = 1;

//

接下来:

for(int i = 2 ; i <= n ; i++){

  if(a[i] > sum + a[i]){

     temp = i;

     sum = a[i];

  }else{

    sum += a[i];

  }

  if(sum > ans){

    ans = sum;

    ans_begin = temp;

    ans_end = i;

  }

}

基本思路如上。

[HDU 1003] Max Sum

标签:

原文地址:http://www.cnblogs.com/ticsmtc/p/5560927.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!