• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

最大子序列和问题

mysql 搞代码 4年前 (2022-01-09) 16次浏览 已收录 0个评论

问题描述: 输入一组整数,求出这组数字子序列和中最大值。也就是只要求出最大子序列的和,不必求出最大的那个序列。例如: 序列:-2 11 -4 13 -5 -2,则最大子序列和为20。 序列:-6 2 4 -7 5 3 2 -1 6 -9 10 -2,则最大子序列和为16。 下面依次给出几个不

问题描述:

输入一组整数,求出这组数字子序列和中最大值。也就是只要求出最大子序列的和,不必求出最大的那个序列。例如:

序列:-2 11 -4 13 -5 -2,则最大子序列和为20。

序列:-6 2 4 -7 5 3 2 -1 6 -9 10 -2,则最大子序列和为16。

下面依次给出几个不同实现算法

int MaxSubseqSum1( int A[], int N )//算法1  T( N ) = O( N3 ){    int ThisSum, MaxSum = 0;    int i, j, k;    for( i = 0; i < N; i++ )   /* i是子列左端位置*/    {        for( j = i; j < N; j++ )   /* j是子列右端位置*/        {            ThisSum = 0; /* ThisSum是从A[i]到A[j]的子列和*/            for( k = i; k  MaxSum ) /* 如果刚得到的这个子列和更大*/                MaxSum = Th<i>本文来源gaodai$ma#com搞$代*码*网</i>isSum; /* 则更新结果*/        } /* j循环结束*/    } /* i循环结束*/    return MaxSum;}int MaxSubseqSum2( int A[], int N )  //算法2T( N ) = O( N2 ){    int ThisSum, MaxSum = 0;    i【本文来自鸿网互联 (http://www.68idc.cn)】nt i, j;    for( i = 0; i < N; i++ )   /* i是子列左端位置*/    {        ThisSum = 0; /* ThisSum是从A[i]到A[j]的子列和*/        for( j = i; j  MaxSum ) /* 如果刚得到的这个子列和更大*/                MaxSum = ThisSum; /* 则更新结果*/        } /* j循环结束*/    } /* i循环结束*/    return MaxSum;}  int MaxSubseqSum4( int A[], int N ) //算法4T( N ) = O( N2 ){    int ThisSum, MaxSum;    int i;    ThisSum = MaxSum = 0;    for( i = 0; i  MaxSum )            MaxSum = ThisSum; /* 发现更大和则更新当前结果*/        else if( ThisSum < 0 ) /* 如果当前子列和为负*/            ThisSum = 0; /* 则不可能使后面的部分和增大,抛弃之*/    }    return MaxSum;}//“在线”的意思是指每输入一个数据就进行即时处理,在任 何一个地方中止输入,算法都能正确给出当前的解。

算法3—分治法


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:最大子序列和问题
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址