一直很少练dp~这几天再学学~~
在本题中:a[i][j]的值表示左上角为(1,1)右下角为(i,j)的矩阵的所有元素之和~
1 4 5 2 2 3 361 649 676 588 992 762 156 993 169 662 34 638 89 543 525 165 254 809 280
2474
#include <iostream> #include <string.h> #include <string> #include <stdio.h> #include <cmath> const int maxn=1010; using namespace std; int a[maxn][maxn]; int main() { int t,n,m,x,y; cin>>t; while(t--) { scanf("%d%d%d%d",&n,&m,&x,&y); memset(a,0,sizeof(a)); for(int i=1;i<=n;i++) //将行叠加 for(int j=1;j<=m;j++) { scanf("%d",&a[i][j]); a[i][j]+=a[i][j-1]; } for(int i=1;i<=n;i++) //将列叠加,都叠加完之后,a[i][j]就表示左上角为(1,1)右下角为(i,j)的矩阵; for(int j=1;j<=m;j++) { a[i][j]+=a[i-1][j]; } //下面开始递推; int Max=a[x][y]; for(int i=x;i<=n;i++) for(int j=y;j<=m;j++) { if(i==x&&j==y)continue; if(i==x&&j!=y) { Max=max(Max,a[i][j]-a[i][j-y]); } else if(i!=x&&j==y) { Max=max(Max,a[i][j]-a[i-x][j]); } else if(i!=x&&j!=y) { Max=max(Max,a[i][j]-a[i][j-y]-a[i-x][j]+a[i-x][j-y]); } } cout<<Max<<endl; } return 0; }
原文:http://blog.csdn.net/liusuangeng/article/details/38612727