分治法求最大子数组

#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;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值