Sum[i][j] 里面的i,j 必须是右下角-左上角+1得出来的大小
#include <bits/stdc++.h>
using namespace std;
int jz[35][34]={0},sum[36][36]={0},i,j,h=0;
int main()
{
for(i=1;i<=30;i++)
for(j=1;j<=20;j++)
{
cin>>jz[i][j];
sum[i][j]=sum[i-1][j]+sum[i][j-1]-sum[i-1][j-1]+jz[i][j];
//前缀和的起点都是左上角第一个点
}
for(i=1;i<=25;i++)
for(j=1;j<=15;j++)
{ int x1=i,y1=j,x2=i+4,y2=j+4;
h=max(h,sum[x2][y2]-sum[x1-1][y2]-sum[x2][y1-1]+sum[x1-1][y1-1]); 求区间和
} sum[x1-1][y2]这块又用了前缀和
cout<<h;
return 0;
}