问一下这一段求数组中最大子序列的值得程序错哪了(实现算法导论中的算法)?求大神指点
问一下这一段求数组中最大子序列的值得程序哪里错了(实现算法导论中的算法)?求大神指点
最近在看算法导论,刚刚试着实现下算法导论(第三版)第四章的求最大子序列的值的算法,但不知道哪里出错,请各位指点。下面是完整代码:
最近在看算法导论,刚刚试着实现下算法导论(第三版)第四章的求最大子序列的值的算法,但不知道哪里出错,请各位指点。下面是完整代码:
#include <iostream>
using namespace std;
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;
left_sum = Find_Maximum_SubArray(A, low, mid);
right_sum = Find_Maximum_SubArray(A, mid + 1, high);
cross_sum = Find_Max_Crossing_SubArray(A, low, mid, high);
if (left_sum >= right_sum && left_sum >= cross_sum)
{
return left_sum;
}
else if (right_sum >= left_sum && right_sum >= cross_sum)
{
return right_sum;
}
else
{
return cross_sum;
}
}
}
int main()
{
int A[100];
int n;
cout<<"Please input the number of numbers:";
cin>>n;
for (int i = 0; i < n; i ++)
{
cin>>A[i];
}
cout<<"最大子序列的和为:"<<Find_Maximum_SubArray(A, 0, n - 1)<<endl;
return 0;
}
- 上一篇:一个面试题,求教!该如何处理
- 下一篇:C++ 11 range for 编译疏失