最大子阵

思路

二维前缀+枚举 6ms

代码

#include <bits/stdc++.h>
using namespace std;

typedef long long ll;
ll a[55][55];
int main()
{
    ll n,m;
    cin>>n>>m;
    for (ll i=1;i<=n;i++) {
        for (ll j=1;j<=m;j++) {
            cin>>a[i][j];
        }
    }
    for (ll i=1;i<=n;i++) {
        for (ll j=1;j<=m;j++) {
            a[i][j]+=a[i-1][j]+a[i][j-1]-a[i-1][j-1];
        }
    }
    ll ans=-(1<<30);
    for (ll i=1;i<=n;i++) {
        for (ll j=1;j<=m;j++) {
            for (ll k=0;k<=i-1;k++) {
                for (ll l=0;l<=j-1;l++) {
                    ans=max(ans,a[i][j]-a[k][j]-a[i][l]+a[k][l]);
                }
            }
        }
    }
    cout<<ans<<endl;
    return 0;
}

原文链接: https://www.cnblogs.com/xyqxyq/p/12377562.html

欢迎关注

微信关注下方公众号,第一时间获取干货硬货;公众号内回复【pdf】免费获取数百本计算机经典书籍;

也有高质量的技术群,里面有嵌入式、搜广推等BAT大佬

    最大子阵

原创文章受到原创版权保护。转载请注明出处:https://www.ccppcoding.com/archives/332504

非原创文章文中已经注明原地址,如有侵权,联系删除

关注公众号【高性能架构探索】,第一时间获取最新文章

转载文章受原作者版权保护。转载请注明原作者出处!

(0)
上一篇 2023年3月1日 下午6:30
下一篇 2023年3月1日 下午6:32

相关推荐