最大子矩陣

描述:

已知矩陣的大小定義爲矩陣中所有元素的和。給定一個矩陣,你的任務是找到最大的非空(大小至少是1 * 1)子矩陣。
比如,如下4 * 4的矩陣
0 -2 -7 0
9 2 -6 2
-4 1 -4 1
-1 8 0 -2
的最大子矩陣是
9 2
-4 1
-1 8
這個子矩陣的大小是15。

分析:

首先,對矩陣預處理一下,將這個涉及多個元素的矩陣轉化成規模更小的問題,可以從上到下處理,也可以從左到右。
從上到下:f[i][j] = f[i-1][j] + a[i][j];

從左到右:f[i][j] = f[i][j-1] + a[i][j];
處理之後,問題轉化爲只涉及兩行元素的簡單問題

#include<iostream>
using namespace std;
int n,a[101][101],f[101][101],sum,ans;
int main() {
    cin>>n;
    for(int i = 1; i<=n; i++) {
        for(int j = 1; j<=n; j++) {
            cin>>a[i][j];
        }
    }
    for(int i = 1; i<=n; i++) {
        for(int j = 1; j<=n; j++) {
            f[i][j] = f[i-1][j] + a[i][j];
        }
    }
    for(int k = 1; k<=n; k++) {
        for(int i = k; i<=n; i++) {
            sum = 0;
            for(int j = 1; j<=n; j++) {
                sum += f[i][j] - f[k-1][j];
                ans = max(sum,ans);
                sum = max(sum,0);
            }
        }
    }
    cout<<ans;
    return 0;
}
#include<iostream>
using namespace std;
int n,a[101][101],f[101][101],sum,ans;
int main() {
    cin>>n;
    for(int i = 1; i<=n; i++) {
        for(int j = 1; j<=n; j++) {
            cin>>a[i][j];
        }
    }
    for(int i = 1; i<=n; i++) {
        for(int j = 1; j<=n; j++) {
            f[i][j] = f[i][j-1] + a[i][j];
        }
    }
    for(int k = 1; k<=n; k++) {
        for(int j = k; j<=n; j++) {
            sum = 0;
            for(int i = 1; i<=n; i++) {
                sum += f[i][j] - f[i][k-1];
                ans = max(sum,ans);
                sum = max(sum,0);
            }
        }
    }
    cout<<ans;
    return 0;
}
發佈了50 篇原創文章 · 獲贊 9 · 訪問量 1萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章