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

数据结构:最大子序列和

时间:2019-05-22 12:39:23      阅读:104      评论:0      收藏:0      [点我收藏+]

标签:计算   ima   inf   src   return   mamicode   子序列和   最大   his   

 

技术图片

算法1:时间复杂度大并且不是很能理解,故不作展示

算法2:

 int MaxSubseqSum2(int A[], int N)
{
    int ThisSum, MaxSum = 0;
    int i, j, k;
    for (i = 0; i<N; i++) //i是子列左端位置
    {
        ThisSum = 0;    //ThisSum是从A[i]到A[j]的子列和
        for (j = i; j<N; j++)    //j是子列右端位置
        {
            ThisSum += A[j];
            if (ThisSum > MaxSum) //如果刚得到的这个子列和更大
            {
                MaxSum = ThisSum; //则更新结果
            }
            } //j循环结束
        } //i循环结束
    return MaxSum;
}

时间复杂度n*n

算法3:分而治之 

技术图片

时间复杂度nlogn

算法4:在线处理 每次输入一个值则立即计算

技术图片

int MaxSubseqSum4(int A[], int N)
{
    int ThisSum, MaxSum;
    int i;
    ThisSum = MaxSum = 0;
    for (i=0; i < N; i++)
    {
        ThisSum += A[i];
        if (ThisSum > MaxSum)
        {
            MaxSum = ThisSum;
        }
        else if (ThisSum < 0)
        {
            ThisSum = 0;
        }
    }
    return MaxSum;
}

 

数据结构:最大子序列和

标签:计算   ima   inf   src   return   mamicode   子序列和   最大   his   

原文地址:https://www.cnblogs.com/zhaoy-shine/p/10904329.html

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