最大子数组的问题

题目不说了 ,下面直接写相关代码:

暴力解法n2版本,不必多说,代码直接走起O(N2)这里为了简便就只返回subarray maxsum的值 如果还要有数组下标 自行改动即可:

int maxsubary(int *s,int n)

{

int maxsum = 0 ;

int sum = 0 ;

int i ;

int j;

for(i=0; i<n; i++){

sum  = 0;

for(j=i; j<n; j++){

sum = sum + s[j];

if(sum > maxsum){

maxsum = sum ;

}

}

}

return maxsum ;

}

暴力解法n3版本:

  1. int MaxSubArray(int *s,int N)  
  2. {  
  3.     int sum=0,maxSum=0;  
  4.     for(int i=0;i<N;++i){  
  5.         for(int j=i;j<N;++j){  
  6.             sum=0;                    
  7.             for(int k=i;k<=j;++k){
  8.                 sum+=s[k];  
  9.             }
  10.              if(sum > maxsum){
  11.                 maxsum = sum ;
  12.              } 
  13. }  
  14.       }  
  15.     return maxSum;  

分治算法 O(nlgn) :

  1. int MaxSubArraySumDC_inArray(int A[],int left,int right)  
  2. {  
  3.     if(left==right)return A[left]>0?A[left]:0;  /*Exit Of Recursive*/  
  4.     int center=(left+right)/2;  
  5.     int leftSum=MaxSubArraySumDC_inArray(A,left,center);  
  6.     int rightSum=MaxSubArraySumDC_inArray(A,center+1,right);  
  7.     int leftSecSum=0,leftSecMaxSum=0;   /*left section*/  
  8.     for(int i=center;i>=left;--i)  
  9.     {  
  10.         leftSecSum+=A[i];  
  11.         leftSecMaxSum=leftSecSum>leftSecMaxSum?leftSecSum:leftSecMaxSum;  
  12.     }  
  13.     int rightSecSum=0,rightSecMaxSum=0; /*right section*/  
  14.     for(int i=center+1;i<=right;++i)  
  15.     {  
  16.         rightSecSum+=A[i];  
  17.         rightSecMaxSum=rightSecSum>rightSecMaxSum?rightSecSum:rightSecMaxSum;  
  18.     }  
  19.     int CenterSum=leftSecMaxSum+rightSecMaxSum; /*get the maxSum from 3 sums*/  
  20.     int resSum=CenterSum;  
  21.     if(resSum<leftSum)resSum=leftSum;  
  22.     if(resSum<rightSum)resSum=rightSum;  
  23.     return resSum;  
  24. }  

动归算法O(n)

int maxsubarray(int *s, int n)

{

int maxsum = s[1] ;

int sum = s[1] ;

int i = 0;

for(i = 0 ; i < n ; i++){

if(sum  > 0){

sum = sum + s[i] ;

}

else{

sum = s[i] ;

}

if(sum > maxsum){

maxsum = sum ;

}

}

return maxsum ;

}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值