分治法求解最大字段问题并输出最大字段和序列

怎么输出最大字段和序列没想出来最好是分治法的。
#include<bits/stdc++.h>
using namespace std;
int MaxSum(int a[],int left,int right)
{
int sum=0;
if(left==right)
{
if(a[left]>0)sum=a[left];
else sum=0;
}
else
{
int center=(left+right)/2;
int leftsum=MaxSum(a,left,center);
int rightsum=MaxSum(a,center+1,right);
int s1=0;int lefts=0;
for(int i=center;i>=left;i--)
{
lefts+=a[i];
if(lefts>s1)s1=lefts;
}
int s2=0;int rights=0;
for(int j=center+1;j<=right;j++)
{
rights+=a[j];
if(rights>s2)s2=rights;
}
sum=s1+s2;
if(sum<leftsum)sum=leftsum;
if(sum<rightsum)sum=rightsum;
}
return sum;
}
int main()
{
int n,a[100],i;
cout<<" 输入序列长度:";
scanf("%d",&n);
cout<<" 原有序列:";
for(i=0;i<n;i++)
{
scanf("%d",&a[i]);
}
int b=MaxSum(a,0,n-1);
cout<<" 该序列字段最大的和为:"<<b;
}

要求还要能输出最大子段和序列

https://blog.csdn.net/qq_41110241/article/details/85317079
cankao

您好,我是有问必答小助手,您的问题已经有小伙伴帮您解答,感谢您对有问必答的支持与关注!
PS:问答VIP年卡 【限时加赠:IT技术图书免费领】,了解详情>>> https://vip.csdn.net/askvip?utm_source=1146287632