题解 | #子矩阵的最大累加和问题#

子矩阵的最大累加和问题

https://www.nowcoder.com/practice/cb82a97dcd0d48a7b1f4ee917e2c0409


// 64 位输出请用 printf("%lld")
#include <iostream>
#include <vector>
#include <climits>

using namespace std;

int maxSumSubarray(vector<int>& arr, int m) {
    int maxSum = INT_MIN;
    int curSum = 0;
    for (int i = 0; i < m; ++i) {
        curSum += arr[i];
        maxSum = max(maxSum, curSum);
        curSum = (curSum < 0) ? 0 : curSum;
    }
    return maxSum;
}

int maxSumSubmatrix(vector<vector<int>>& mat, int n, int m) {
    int maxSum = INT_MIN;
    for (int i = 0; i < n; ++i) {
        vector<int> arr(m, 0);
        for (int j = i; j < n; ++j) {
            for (int k = 0; k < m; ++k) {
                arr[k] += mat[j][k];
            }
            maxSum = max(maxSum, maxSumSubarray(arr, m));
        }
    }
    return maxSum;
}

int main() {
    ios_base::sync_with_stdio(false);
    cin.tie(nullptr);
    
    int n, m;
    while (cin >> n >> m) {
        vector<vector<int>> mat(n, vector<int>(m));
        for (int i = 0; i < n; ++i) {
            for (int j = 0; j < m; ++j) {
                cin >> mat[i][j];
            }
        }
        cout << maxSumSubmatrix(mat, n, m) << "\n";
    }

    return 0;
}

全部评论

相关推荐

在评审的大师兄很完美:像这种一般就是部门不匹配 转移至其他部门然后挂掉 我就是这样被挂了
点赞 评论 收藏
分享
有趣的牛油果开挂了:最近这个阶段收到些杂七杂八的短信是真的烦
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务