最大子矩阵和
#include <iostream>
#include <vector>
#include <climits>
#include <algorithm>
using namespace std;
vector<int> maxContinuousSubsectionSum(vector<int> nums) {
long n = nums.size();
if (n <= 0)
return {0, 0, 0};
vector<int> dp(n);
vector<int> start(n);
dp[0] = nums[0];
start[0] = 0;
for (int i = 1; i < n; i++) {
if (dp[i - 1] > 0) {
dp[i] = dp[i - 1] + nums[i];
start[i] = start[i - 1];
} else {
dp[i] = nums[i];
start[i] = i;
}
}
int left = 0, right = 0;
int maximum = dp[0];
for (int i = 1; i < n; i++) {
if (dp[i] > maximum) {
maximum = dp[i];
left = start[i];
right = i;
}
}
return {maximum, left, right};
}
vector<int> maxSubMatrixSum(vector<vector<int>> mat) {
// m 行,n 列
long m = mat.size();
if (m <= 0)
return {0, 0, 0, 0, 0};
long n = mat[0].size();
if (n <= 0)
return {0, 0, 0, 0, 0};
for (int i = 1; i < m; i++) {
for (int j = 0; j < n; j++) {
mat[i][j] += mat[i - 1][j];
}
}
int maximum = mat[0][0];
int top = 0, bottom = 0, left = 0, right = 0;
for (int i = 0; i < m; i++) {
for (int j = i; j < m; j++) {
vector<int> tmp(n);
for (int k = 0; k < n; k++) {
if (i == 0) {
tmp[k] = mat[j][k];
} else {
tmp[k] = mat[j][k] - mat[i - 1][k];
}
}
vector<int> currentMax = maxContinuousSubsectionSum(tmp);
if (currentMax[0] > maximum) {
maximum = currentMax[0];
left = currentMax[1];
right = currentMax[2];
top = i;
bottom = j;
}
}
}
return {maximum, top, bottom, left, right};
}
int main() {
vector<vector<int>> nums = {{0, -2, 7, 0},
{9, 2, -6, 2},
{-4, 1, -4, 1},
{-1, 8, 0, -2},
{-1, 2, 0, -2}};
vector<int> res = maxSubMatrixSum(nums);
int maximum = res[0], top = res[1], bottom = res[2], left = res[3], right = res[4];
cout << "最大子矩阵和为:" << maximum << endl;
cout << "左上角和右下角坐标为:";
cout << "(" << top << ", " << left << "), (" << bottom << ", " << right << ")" << endl;
return 0;
}
参考:https://blog.csdn.net/beiyeqingteng/article/details/7056687