首页 > 其他 > 详细

HDU 1231 最大连续子序列 --- 入门DP

时间:2016-02-19 01:36:17      阅读:129      评论:0      收藏:0      [点我收藏+]

  HDU 1231

  题目大意以及解题思路见: HDU 1003题解,此题和HDU 1003只是记录的信息不同,处理完全相同。

技术分享
/* HDU 1231 最大连续子序列 --- 入门DP */
#include <cstdio>
#include <cstring>

int dp[10005];

int main()
{
#ifdef _LOCAL
    freopen("D:\\input.txt", "r", stdin);
#endif
    int n;
    int maxSum, fst, lst;
    int start, ai;    //start用于记录起始位置,ai表示a[i],这样可以省去一个数组
    while (scanf("%d", &n) == 1 && n){
        for (int i = 0; i < n; ++i){
            scanf("%d", dp + i);
        }//for(i)

        start = lst = fst = maxSum = dp[0];
        for (int i = 1; i < n; ++i){
            ai = dp[i];
            if (dp[i - 1] >= 0){
                dp[i] = dp[i - 1] + dp[i];
            }
            else{
                start = dp[i];
            }

            if (dp[i] > maxSum){
                maxSum = dp[i];
                fst = start;
                lst = ai;//这是dp[i]已经更新了,不再是原来的a[i],因此需要提前记录下来
            }
        }//for(i)
        if (maxSum < 0){
            printf("0 %d %d\n", dp[0], dp[n - 1]);
        }
        else{
            printf("%d %d %d\n", maxSum, fst, lst);
        }
    }

    return 0;
}
View Code

 

HDU 1231 最大连续子序列 --- 入门DP

原文:http://www.cnblogs.com/tommychok/p/5199678.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!