#include <stdio.h>
//1.假设最大子数组跨越中点,得到跨越中点的最大子数组。
int Find_Max_Crossing_SubArray(int A[], int low, int mid, int high)
{
int left_sum = -0xff;
int sum = 0;
//得到左边的最大子数组
for (int i = mid; i >= low; i --)
{
sum += A[i];
if (sum >left_sum)
{
left_sum = sum;
}
}
int right_sum = -0xff;
sum = 0;
//得到右边的最大子数组
for (int j = mid + 1; j <= high; j ++)
{
sum += A[j];
if (sum > right_sum)
{
right_sum = sum;
}
}
//合并,得到跨越中点的最大子数组
return left_sum + right_sum;
}
int Find_Maximum_SubArray(int A[], int low, int high)
{
int left_sum, right_sum, cross_sum;
//结束递归的条件。当把数组分到只剩一个元素时,结束递归。
if (high == low)
{
return A[low];
}
else
{
//最大子数组分三种可能,不是在最左边就是在最右边,要不就是跨越中点。
int mid = (low + high) / 2;
//1.求出最左边的最大值
left_sum = Find_Maximum_SubArray(A, low, mid);
//2.求出最右边的最大值
right_sum = Find_Maximum_SubArray(A, mid + 1, high);
//3.求出跨越中点的最大值
cross_sum = Find_Max_Crossing_SubArray(A, low, mid, high);
//1.最左边
if (left_sum >= right_sum && left_sum >= cross_sum)
{
return left_sum;
}
//2.最右边
else if (right_sum >= left_sum && right_sum >= cross_sum)
{
return right_sum;
}
//3.跨越中点
else
{
return cross_sum;
}
}
}
int main()
{
int A[100];
int n;
printf("Please input the number of numbers:");
scanf("%d",&n);
for (int i = 0; i < n; i ++)
{
scanf("%d",&A[i]);
}
printf("最大子序列的和为:%d",Find_Maximum_SubArray(A, 0, n - 1));
return 0;
}
分治法求最大子数组
最新推荐文章于 2022-04-19 16:24:09 发布