最大子列和——分而治之(mooc浙江大学数据结构)

#include <iostream>
#include <windows.h>
using namespace std;

//算中间的部分
int midCount(int a[], int i, int j)
{
	int mid = (i + j) / 2;
	int max = 0;
	int all = 0;

	for (int lengthLeft = mid - 1; lengthLeft >= i; lengthLeft--)
	{
		all += a[lengthLeft];
		max = (all > max ? all : max);
	}

	all = max;

	for (int lengthRight = mid; lengthRight < j; lengthRight++)
	{
		all += a[lengthRight];
		max = (all > max ? all : max);
	}

	return max;
}

int getMaxSonline(int a[], int i, int j)
{
	int mid = (i + j) / 2;
	int left;
	int midCountMath;
	int right;
	int max = 0;
	int all = 0;
	if (i + 1 == j || i == j)
	{
		return a[i];
	}
	else
	{
		midCountMath = midCount(a, i, j);
		left = getMaxSonline(a, i, mid - 1);
		right = getMaxSonline(a, mid, j);
		max = left > right ? left : right;
		max = max > midCountMath ? max : midCountMath;
		return max;
	}
}

int main()
{
	int n;
	cin >> n;
	int a[n];
	for (int i = 0; i < n; i++)
	{
		cin >> a[i];
	}

	int max = getMaxSonline(a, 0, n);
	cout << max << endl;
	system("pause");
	return 0;
}
分而治之是一种常用的算法思想,可以用来解决最大子列和问题。在这种方法中,我们将问题分解成更小的子问题,并在每个子问题上递归地应用该方法。然后,我们将子问题的解合并起来,形成原始问题的解。 下面是使用分而治之方法解决最大子列和问题的Python代码: ```python def max_subarray_sum(arr, low, high): # 递归终止条件,当只有一个元素时返回该元素 if low == high: return arr[low] # 分治法的分解步骤,将问题分解为更小的子问题 mid = (low + high) // 2 left_max = max_subarray_sum(arr, low, mid) right_max = max_subarray_sum(arr, mid + 1, high) # 分治法的合并步骤,将子问题的解合并得到原始问题的解 cross_max = max_crossing_sum(arr, low, mid, high) # 返回左子数组最大子列和、右子数组最大子列和和跨越中点的最大子列和中的最大值 return max(left_max, right_max, cross_max) def max_crossing_sum(arr, low, mid, high): # 计算包含中点的左侧最大子列和 left_sum = float("-inf") curr_sum = 0 for i in range(mid, low - 1, -1): curr_sum += arr[i] if curr_sum > left_sum: left_sum = curr_sum # 计算包含中点的右侧最大子列和 right_sum = float("-inf") curr_sum = 0 for i in range(mid + 1, high + 1): curr_sum += arr[i] if curr_sum > right_sum: right_sum = curr_sum # 返回左侧最大子列和、右侧最大子列和和跨越中点的最大子列和的和 return left_sum + right_sum # 测试代码 arr = [-2, 11, -4, 13, -5, -2] max_sum = max_subarray_sum(arr, 0, len(arr) - 1) print(max_sum) ``` 这段代码通过递归地将问题分解为更小的子问题,并在每个子问题上应用该方法。然后,它将子问题的解合并起来,得到原始问题的解。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值