求最大子序列和

给定K个整数的序列{N1, N2, ..., NK },其任意连续子序列可表示为{ Ni, Ni+1, ..., 

Nj},其中 1 <= i <= j <= K。最大连续子序列是所有连续子序列中元素和最大的一个, 

例如给定序列{-2, 11, -4, 13, -5, -2 },其最大连续子序列为{ 11, -4, 13 },最大和 

为20。 

 

 

 

/*

动态规划实现,算法复杂度O(n)

*/

intmaxSubSequenceSum3(int a[], int len)

{

    int i;

    int curSum; /* 当前序列和 */

    int maxSum; /* 最大序列和 */

 

    /* 初始化当前序列和为0 */

    curSum = 0;

 

    /* 初始化最大子序列和为序列第一个元素 */

    maxSum = a[0];

 

    /* 开始循环求子序列和 */

    for (i = 0; i < len;i++)

    {

       curSum = curSum + a[i];

 

        /* 与最大子序列和比较,更新最大子序列和 */

       if (curSum > maxSum)

        {

            maxSum = curSum;

        }

 

        /* 动态规划部分,舍弃当前和为负的子序列 */

       if (curSum < 0)

        {

            curSum = 0;

        }

    }

    return maxSum;

}

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值