#include<iostream>
#include<cstring>
using namespace std;
int main ()
{
int n,m;
int s[52][52];
while(scanf("%d %d",&n,&m)!=EOF)
{
for(int i=0;i<n;i++)
for(int j=0;j<n;j++)
cin>>s[i][j];
int max=0;
for(int i=0;i<=n-m;i++)
{
for(int j=0;j<=n-m;j++)
{
int sum=0;
for(int a=i;a<m+i;a++)
{
for(int b=j;b<m+j;b++)
{
sum+=s[a][b];
}
}
if(sum>max)
max=sum;
}
}
cout<<max<<endl;
}
return 0;
}
这也是个暴力题目。
我的做法是,建立一个二维整数数组来存放数据,然后以矩阵的左上角为起点,计算一个m*m大小的和,然后找到起点的范围,进行循环,找到最大值。