分治法—最大子段问题

cs 复制代码
#include<stdio.h>
#include<stdlib.h>
//分治法
//最大子段问题
int Maxsubsum(int* Array, int left, int right)
{
	int sum = 0,i;
	//当array只有一个元素的时候
	if (left == right)
	{
		if (Array[left] > 0) {
			sum = Array[left];
		}
		else
		{
			sum = 0;
		}
	}
	else
	{
		int center = (left + right) / 2;
		int leftsum = Maxsubsum(Array, left, center);
		int rightsum = Maxsubsum(Array, center + 1, right);
		int s1 = 0;
		int lefts = 0;
		for (i = center;i >= left; i--)
		{
			lefts = lefts + Array[i];
			if (lefts>s1)
			{
				s1 = lefts;
			}
		}
		int s2 = 0;
		int rights = 0;
		for (i = center + 1; i <= right; i++)
		{
			rights = rights + Array[i];
			if (rights>s2)
			{
				s2 = rights;
			}
		}
		sum = s1 + s2;//最大子段问题的第三种情况
		
		//第一种情况
		if (sum < leftsum)
		{
			sum = leftsum;
		}
		//第二种情况
		if (sum < rightsum)
		{
			sum = rightsum;
		}
	}
	return sum;
}
int main()
{
	int* Array = (int*)malloc(6 * sizeof(int));
	Array[0] = -2;
	Array[1] = 11;
	Array[2] = -4;
	Array[3] = 13;
	Array[0] = -5;
	Array[0] = -2;
  	int result = Maxsubsum(Array, 0, 5);
	printf("%d", result);
	return 0;
}

时间复杂度为:O(nlogn)

相关推荐
唐青枫20 分钟前
线程不是越多越快:C#.NET Thread 生命周期、同步与后台工作线程实战
c#·.net
半个落月1 小时前
从递归到快速排序:用 JavaScript 把分治思想讲明白
javascript·算法·面试
小月土星2 小时前
JavaScript 快速排序:从 pivot、双指针到分治思想
javascript·算法·面试
小月土星2 小时前
JavaScript 递归入门:从 1 到 n 求和,再到数组扁平化
javascript·算法·面试
To_OC17 小时前
LC 1 两数之和:面试第一道必考题,暴力解法直接被面试官 pass
javascript·算法·leetcode
鱼鱼不愚与1 天前
《原来如此 | 第01期:为什么导航软件能预测红绿灯倒计时?》
算法
唐青枫1 天前
别只会反射:C#.NET Emit 动态生成代码实战详解
c#·.net
咕白m6251 天前
.NET 环境下 Word 超链接批量提取方案
c#·.net
复杂网络1 天前
论最小 Agent 计算机的形态
算法