最大子段和(c++)

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了最大子段和(c++)相关的知识,希望对你有一定的参考价值。

// 最大子段和.cpp : 定义控制台应用程序的入口点。
//
#include "stdafx.h"
#include<iostream>
using namespace std;
int MaxSum_test(int v[], int l, int r)
{
 int k,sum = 0;
 if (l ==r)
 {
   return v[l] >= 0 ? v[l]:0;
 }
 else
 {
  int center = (l+ r) / 2;
  int  lsum = MaxSum_test(v, l, center);
  int rsum = MaxSum_test(v, center + 1, r);
  int s1 = 0;
  int lefts = 0;
  for (k = center; k >= l; k--)
  {
   lefts += v[k];
   if (lefts>s1)
    s1 = lefts;
  }
  int s2 = 0;
  int rights = 0;
  for (k = center + 1; k <= r; k++)
  {
   rights += v[k];
   if (rights>s2)
    s2 = rights;
  }
  sum = s1 + s2;
  if (sum<lsum)
   sum = lsum;
  if (sum<rsum)
   sum = rsum;
 }
 return sum;
}
int _tmain(int argc, _TCHAR* argv[])
{
 int arr[6] = { -20, 11, -4, 13, -5, -2 };
 cout <<"最大子段长度为:"<< MaxSum_test(arr, 0, 5) << endl;
 return 0;
}
 

 

以上是关于最大子段和(c++)的主要内容,如果未能解决你的问题,请参考以下文章

算法笔记--最大子段和问题

最大子段和

线段树维护区间最大子段和

动态规划 ------最大子段和

最大子段和问题,最大子矩阵和问题,最大m子段和问题

51nod 最大子段和