对于三个正方形的位置一共有六种情况。

预处理出(i,j)左上角,左下角,右上角,右下角区域内最大权值的正方形。

枚举分界线更新答案。

刚开始想了一个错误的DP也是蠢啊。

#include<set>
#include<map>
#include<ctime>
#include<queue>
#include<cmath>
#include<cstdio>
#include<vector>
#include<cstring>
#include<cstdlib>
#include<iostream>
#include<algorithm>
#define inf 100000000000000LL
#define pa pair<int,int>
#define ll long long
#define N 2505
#define fp(a,b,c) for(int a=b;a<=c;a++)
#define fd(a,b,c) for(int a=c;a>=b;a--)
using namespace std;
int n,m,K,ans;
int a[N][N],b[N][N],c[N][N],d[N][N],s[N][N];
int main()
{
scanf("%d%d%d",&n,&m,&K);
fp(i,,n)fp(j,,m)
{
int x;scanf("%d",&x);
s[i][j]=s[i-][j]+s[i][j-]-s[i-][j-]+x;
}
fd(i,K,n)fd(j,K,m)s[i][j]-=s[i-K][j]+s[i][j-K]-s[i-K][j-K]; fp(i,K,n)fp(j,K,m)a[i][j]=max(s[i][j],max(a[i-][j],a[i][j-]));
fp(i,K,n)fd(j,K,m)b[i][j]=max(s[i][j],max(b[i-][j],b[i][j+]));
fd(i,K,n)fp(j,K,m)c[i][j]=max(s[i][j],max(c[i+][j],c[i][j-]));
fd(i,K,n)fd(j,K,m)d[i][j]=max(s[i][j],max(d[i+][j],d[i][j+])); fp(i,K,n-K)fp(j,K,m-K)ans=max(ans,a[i][j]+b[i][j+K]+c[i+K][m]);
fp(i,K,n-K)fp(j,K+K,m)ans=max(ans,b[i][j]+d[i+K][j]+a[n][j-K]);
fp(i,K+K,n)fp(j,K,m-K)ans=max(ans,c[i][j]+d[i][j+K]+a[i-K][m]);
fp(i,K,n-K)fp(j,K,m-K)ans=max(ans,a[i][j]+c[i+K][j]+b[n][j+K]); fp(i,K,n)fp(j,K+K,m-K)ans=max(ans,s[i][j]+a[n][j-K]+b[n][j+K]);
fp(i,K+K,n-K)fp(j,K,m)ans=max(ans,s[i][j]+a[i-K][m]+c[i+K][m]); printf("%d\n",ans);
return ;
}

最新文章

  1. Mac系统下配置JDK环境变量
  2. 项目分享二:APP 小红点中数字的处理
  3. 使用ab压测网页结果分析
  4. MSP430G2333下位机乘法运算需要注意的一个问题
  5. js检测是否安装了flash插件
  6. js中的prototype和constructor
  7. React-非dom属性-key
  8. 关于AVAudioPlayer
  9. C++ 数据结构学习二(单链表)
  10. JS中var和let
  11. javaScript属性
  12. mysql has gone away
  13. h5新增标签及css3新增属性
  14. [PGM] Variable elimination and Belief propagation
  15. react-redux 使用后台数据初始化(渲染)界面
  16. jsp中&lt;%两个最容易搞混淆的用法,附:out.println与out.write的用法
  17. 让WebBrowser在非兼容模式下运行
  18. windows7安装node
  19. A Tool To Plot Mathematical Function
  20. 动态展开tableView的cell[2]

热门文章

  1. 20155320 2016-2017-2《Java程序设计》第1周学习总结
  2. JDK1.7的HashMap的put(key, value)源码剖析
  3. BZOJ4049][CERC2014]Mountainous landscape-[线段树+凸包+二分]
  4. [agc006F]Blackout
  5. LVS入门篇(二)之LVS基础
  6. OpenGL ES学习笔记(二)&mdash;&mdash;平滑着色、自适应宽高及三维图像生成
  7. Python小白学习之函数装饰器
  8. IncDec序列:差分+贪心
  9. 多重共性和VIF检验
  10. 如何报FOB价格