Sam_Gamer @ 2023-08-10 22:27:31
#include<bits/stdc++.h>
#define maxn 125
using namespace std;
int main()
{
long long a[maxn][maxn],b[maxn][maxn],n,ans=-2100000000;
cin>>n;//套公式
for(int i=1;i<=n;i++)
{
for(int j=1;j<=n;j++)
{
cin>>a[i][j];
}
}
b[0][0]=a[0][0];
for(int i=1;i<=n;i++)
{
for(int j=1;j<=n;j++)
{
b[i][j]=b[i-1][j]+b[i][j-1]-b[i-1][j-1]+a[i][j];//处理上,左
}
}
for(int i=1;i<=n;i++)
{
for(int j=1;j<=n;j++)
{
for(int k=1;k<=n;k++)
{
for(int l=1;l<=n;l++)
{
if(ans<(b[k][l]-b[k][j-1]-b[i-1][l]+b[i-1][j-1])) ans=(b[k][l]-b[k][j-1]-b[i-1][l]+b[i-1][j-1]);
}
}
}
}
cout<<ans;
return 0;
}
用了二位前缀和和区间和,但是样例得17(样例15)
by Sam_Gamer @ 2023-08-10 22:28:12
刚开始以为是ans=0的问题,但貌似不是
by linxuanrui @ 2023-08-10 22:42:09
@Sam_Gamer 这里一共有 3 个错误。
把 a,b
定义成全局数组,因为处理 b[1][1]
时用到了 b[1][0]
,而 b[1][0]
没有定义 。
for(int k=1;k<=n;k++)
应为 for(int k=i;k<=n;k++)
,因为你不可能让开始的坐标大于结束的坐标吧。
for(int l=1;l<=n;l++)
:同上。
by Sam_Gamer @ 2023-08-10 23:03:49
@linxuanrui 谢谢