【分治问题--最大子序列和问题--03】

最大子序列和的问题

思想描述:将K个整数组成的序列{N1,N2,…,Ni},“连续子列”被定义为{Ni,Ni+1,…,Nj},其中1<=i<=j<=k;最大子序列和的问题被定义为所有连续子列元素的和的最大值(如果子列和为负值,那么直接舍弃,对后面的子列贡献为负)。

#include <stdio.h>
#define MaxValue 100
int Max(int A,int B,int C)
{
	return (A>B?) && (A>C?) A:B>C? B:C;
}
int DivideAadConquer(int A[],int start,int last)
{
	int MaxLeftSum=0,MaxRightSum=0;//为左右单个数字
	int MaxLeft=0,MaxRight=0;//为左右最大的和,
	int LeftSum=0,RightSum=0;
	mid = (start+last)/2;
	if(start>=last)//数组仅存在一个元素的情况
	{
	//保证开头就是>0的数值
		if(start<=left)
			return start[0]>0?start[0]:0;
	}
	//分解数组为左右两个数组
	else
	{
		if(start<mid && mid+1<last)
		{
			//划分左侧子数组
			MaxLeftSum = DivideArray(A,start,start+mid);
			//划分右侧子数组
			MaxrightSum = DivideArray(A,start+mid+1,last);
			//进行序列求和
			//求左侧最大子列和//从中线向左
			for(int i = mid;i>=left;i--)
			{
				LeftSum +=List[i];
				if(LeftSum>MaxRight)
					{MaxRight = LeftSum;}
			}
			//求右侧最大子序列和//从中线向右
			for(int i = mid+1;i<=right;i++)
			{
				RightSum += List[i];
				if(MaxRight<RightSum)
				{
					MaxRight = RightSum;
				}
			}
			return Max(MaxLeftSum,MaxRightSum,MaxLeft+MaxRight);
		}
	}
}
int main()
{
	int A[MaxValue];
	int n;
	int B[MaxValue];
	scanf("%d",&n);
	//输入数据
	for(int i=0;i<n;i++)
	{
		scanf("%d",&A[i]);
	}
	//开始将数组分成子数组
	DivideAadConquer(A,0,n-1);
	return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值