最大子阵
思路
二维前缀+枚举 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;
}