最大子序列和

来源:互联网 发布:mac怎么看系统 编辑:程序博客网 时间:2024/05/18 09:53

   三种最大子序列和问题解法

#include<stdio.h>
int MaxsubseqSum4(int A[],int N);
int MaxsubseqSum1(int B[],int n);
//最大子列和
int main()
{
int a[8]={-1,3,-2,4,-6,1,6,-1};
int k,i;
k=8;
k=MaxsubseqSum4(a,k);
printf("%d",k);
k=MaxsubseqSum1(a,k);
printf("%d",k);

return 0;
}
int MaxsubseqSum4(int A[],int k)  //最优解法,只用一层循环,从第一个开始小于零丢弃,只遍历一次就能得出最大子序列和。
{
  int Maxsum,thissum;
  int i;
  thissum=0;
  Maxsum=0;
  
for(i=0;i<k;i++)
 {
  thissum+=A[i];
  if(thissum>Maxsum)
   Maxsum=thissum;
   else if(thissum<0)
 thissum=0;


}
printf("%d",Maxsum);
return Maxsum;
}
int MaxsubseqSum1(int B[],int k)
{
int ThisSum,Maxsum=0;
//三层嵌套for循环  时间复杂度n^3。 很麻烦。 先从0加到最后 再从1加到最后  。。。。如果i=1,j=3  那么 thissum=a1+a2+a3     j=4  重复(a1+a2+a3)+a4   



int i,j,l;
for(i=0;i<k;i++)
 {
   for(j=i;j<k;j++)
for(l=i;l<j;l++)//第三次
{
ThisSum+=B[l];
if(ThisSum>Maxsum)
Maxsum=ThisSum;       //
}
}
return Maxsum;





}
int MaxsubseqSum2(int B[],int k)   //递推
{
int thissum,maxsum=0;
int j,i;
for(i=0;i<k;i++)
{
thissum=0;
for(j=i;j<k;j++)
{
thissum+=B[j];   // 3 -5 8 -7 6   //递推将上面的进行了优化   Sum(i,j)=sum(i,j-1)+aj   通过这个公式,减少了一层for循环。

if(thissum>maxsum)   //
 maxsum=thissum;
}
}
}

0 0
原创粉丝点击