题目
对最大子数组问题,编写暴力求解方法的伪代码,其运行时间应该是θ(n^2)
。
题解
θ(n^2)
的方法是通过保存二维数组的上一个计算结果,即i..j
的和,来计算i..j+1
的和。
用c++
代码写一遍。
#include <cstdio>
#include <cstring>
#include <climits>
struct Sub {
int low;
int high;
int sum;
};
Sub FindMaximumSubarray(const int array[], int count) {
int sum[count][count];
Sub maxSub = { 0, 0, -INT_MIN};
for (int i = 0; i < count; ++i) {
for (int j = i; j < count; ++j) {
if (i != j) {
sum[i][j] = sum[i][j-1] + array[j];
} else {
sum[i][j] = array[j];
}
if (sum[i][j] > maxSub.sum) {
maxSub = { i, j, sum[i][j] };
}
}
}
return maxSub;
}
int main() {
int arr[] = { 13, -3, -25, 20, -3, -16, -23, 18, 20, -7, 12, -5, -22, 15, -4, 7 };
Sub ans = FindMaximumSubarray(arr, sizeof(arr)/sizeof(arr[0]));
printf("low = %d, high = %d, sum = %d", ans.low, ans.high, ans.sum);
return 0;
}
附上github代码地址: https://github.com/FengHaiTongLuo/Introduction-to-Algorithms-Prac/blob/main/prac_4.1-2.cpp
通过微信公众号”风海铜锣技术君“的菜单可以加我入面试交流的”程序员卷卷群“。