BZOJ 1057 棋盘制作
Description
国际象棋是世界上最古老的博弈游戏之一,和中国的围棋、象棋以及日本的将棋同享盛名。据说国际象棋起源于易经的思想,棋盘是一个8*8大小的黑白相间的方阵,对应八八六十四卦,黑白对应阴阳。而我们的主人公小Q,正是国际象棋的狂热爱好者。作为一个顶尖高手,他已不满足于普通的棋盘与规则,于是他跟他的好朋友小W决定将棋盘扩大以适应他们的新规则。小Q找到了一张由N*M个正方形的格子组成的矩形纸片,每个格子被涂有黑白两种颜色之一。小Q想在这种纸中裁减一部分作为新棋盘,当然,他希望这个棋盘尽可能的大。不过小Q还没有决定是找一个正方形的棋盘还是一个矩形的棋盘(当然,不管哪种,棋盘必须都黑白相间,即相邻的格子不同色),所以他希望可以找到最大的正方形棋盘面积和最大的矩形棋盘面积,从而决定哪个更好一些。于是小Q找到了即将参加全国信息学竞赛的你,你能帮助他么?
Input
第一行包含两个整数N和M,分别表示矩形纸片的长和宽。接下来的N行包含一个N * M的01矩阵,表示这张矩形纸片的颜色(0表示白色,1表示黑色)。
Output
包含两行,每行包含一个整数。第一行为可以找到的最大正方形棋盘的面积,第二行为可以找到的最大矩形棋盘的面积(注意正方形和矩形是可以相交或者包含的)。
Sample Input
1 0 1
0 1 0
1 0 0
Sample Output
6
HINT
对于100%的数据,N, M ≤ 2000
for (int i = ;i <= n;++i)
{
int lo = ,ro = m+;
for (int j = ;j <= m;++j)
{
if (s[i][j] == sign) up[i][j] = le[i][j] = ,lo = j;
else up[i][j] = i==?:up[i-][j]+,le[i][j] = i==?lo+:max(le[i-][j],lo+);
}
for (int j = m;j;--j)
{
if (s[i][j] == sign) ri[i][j] = m+,ro = j;
else ri[i][j] = i==?ro-:min(ri[i-][j],ro-);
int a = up[i][j],b = ri[i][j]-le[i][j]+,p = min(a,b);
ans1 = max(ans1,p*p); ans2 = max(ans2,a*b);
}
}
总代码:
#include<iostream>
#include<cstdio>
#include<cstdlib>
using namespace std; #define maxn 2010
int s[maxn][maxn],le[maxn][maxn],ri[maxn][maxn];
int up[maxn][maxn],n,m,ans1,ans2; inline void work()
{
for (int i = ;i <= n;++i)
{
for (int j = ;j <= m;++j)
{
if (i == || s[i][j] == s[i-][j]) up[i][j] = ;
else up[i][j] = up[i-][j]+;
}
}
} inline void deal()
{
for (int i = ;i <= n;++i)
for (int j = ;j <= m;++j)
if ((i + j)&) s[i][j] ^= ;
} inline void work(int sign)
{
for (int i = ;i <= n;++i)
{
int lo = ,ro = m+;
for (int j = ;j <= m;++j)
{
if (s[i][j] == sign) up[i][j] = le[i][j] = ,lo = j;
else up[i][j] = i==?:up[i-][j]+,le[i][j] = i==?lo+:max(le[i-][j],lo+);
}
for (int j = m;j;--j)
{
if (s[i][j] == sign) ri[i][j] = m+,ro = j;
else ri[i][j] = i==?ro-:min(ri[i-][j],ro-);
int a = up[i][j],b = ri[i][j]-le[i][j]+,p = min(a,b);
ans1 = max(ans1,p*p); ans2 = max(ans2,a*b);
}
}
} int main()
{
freopen("1057.in","r",stdin);
freopen("1057.out","w",stdout);
scanf("%d %d",&n,&m);
for (int i = ;i <= n;++i)
for (int j = ;j <= m;++j) scanf("%d",s[i]+j);
deal(); work(); work();
printf("%d\n%d",ans1,ans2);
fclose(stdin); fclose(stdout);
return ;
}
BZOJ 1057 棋盘制作的更多相关文章
- BZOJ 1057 棋盘制作(最大01相间子矩阵)
求最大01相间子矩阵可以转换为求最大全0子矩阵.只需把棋盘(x+y)为奇数的取反,而该问题可以用经典的悬线法O(n^2)的求解. 悬线法呢. 首先定义b[i][j],为a[i][j]向上的最大连续0的 ...
- 【以前的空间】bzoj [ZJOI2007]棋盘制作
具体可以去跪<浅谈用极大化思想解决最大子矩形问题>(p.s. 蒟蒻跪了还是很晕,不过想到之前usaco好像是最后一章的一道题……看了下代码顿然醒悟) 也就是如果用o(nm)的方法维护一个极 ...
- bzoj 1057: [ZJOI2007]棋盘制作 单调栈
题目链接 1057: [ZJOI2007]棋盘制作 Time Limit: 20 Sec Memory Limit: 162 MBSubmit: 2027 Solved: 1019[Submit] ...
- BZOJ 1057: [ZJOI2007]棋盘制作( dp + 悬线法 )
对于第一问, 简单的dp. f(i, j)表示以(i, j)为左上角的最大正方形, f(i, j) = min( f(i + 1, j), f(i, j + 1), f(i + 1, j + 1)) ...
- 【BZOJ 1057】 1057: [ZJOI2007]棋盘制作
1057: [ZJOI2007]棋盘制作 Description 国际象棋是世界上最古老的博弈游戏之一,和中国的围棋.象棋以及日本的将棋同享盛名.据说国际象棋起源 于易经的思想,棋盘是一个8*8大小的 ...
- BZOJ 1057: [ZJOI2007]棋盘制作 悬线法求最大子矩阵+dp
1057: [ZJOI2007]棋盘制作 Description 国际象棋是世界上最古老的博弈游戏之一,和中国的围棋.象棋以及日本的将棋同享盛名.据说国际象棋起源于易经的思想,棋盘是一个8*8大小的黑 ...
- 悬线法 || BZOJ 1057: [ZJOI2007]棋盘制作 || Luogu P1169 [ZJOI2007]棋盘制作
题面:P1169 [ZJOI2007]棋盘制作 题解: 基本是悬线法板子,只是建图判断时有一点点不同. 代码: #include<cstdio> #include<cstring&g ...
- BZOJ 1057:[ZJOI2007]棋盘制作(最大01子矩阵+奇偶性)
[ZJOI2007]棋盘制作 时间限制: 20 Sec 内存限制: 162 MB[题目描述]国际象棋是世界上最古老的博 ...
- 棋盘制作 BZOJ 1057
棋盘制作 [问题描述] 国际象棋是世界上最古老的博弈游戏之一,和中国的围棋.象棋以及日本的将棋同享盛名.据说国际象棋起源于易经的思想,棋盘是一个8*8大小的黑白相间的方阵,对应八八六十四卦,黑白对应阴 ...
随机推荐
- IE浏览器中发送到onenote的选项没有调出来??
最近使用onenote 作为笔记本,发现这个比word好用很多,特别是还有一个功能很好用,发送到onenote,可以选中网页中的内容,发送到onenote.但是有一些IE浏览器这个选项没有调出来,还是 ...
- 弹出窗口zDialog的使用
因为没有元素可以显示到Frameset上面去,所以重新定义了,一个index.htm,对其的操作是: Index.htm <script language="javascript ...
- hive 配置文件以及join中null值的处理
一.Hive的參数设置 1. 三种设定方式:配置文件 · 用户自己定义配置文件:$HIVE_CONF_DIR/hive-site.xml · 默认配置文件:$HIVE_CONF_DIR/hi ...
- MYSQL 调优系列
http://www.cnblogs.com/digdeep/p/4847484.html
- web.xml常用标签整理(不定期更新)
<?xml version="1.0" encoding="UTF-8"?><!-- 标明使用的XML版本和文档编码,此项必须位于第一行,之前 ...
- iOS Multiview Applications
@import url(http://i.cnblogs.com/Load.ashx?type=style&file=SyntaxHighlighter.css); @import url(/ ...
- 知识点摸清 - - function()——JavaScript 函数名后什么时候加括号,什么时候不
加括号——调用函数 只要是要调用函数执行的,都必须加括号. 此时,function()实际上等于函数的返回值.(没有返回值也已经执行了函数体内的行为).就是说,只要加括号的,就代表将会执行函数体代码. ...
- Java-Android 之输入提示框
Android的文本提示框有两种方式: main.xml文件 <?xml version="1.0" encoding="utf-8"?> < ...
- c#迭代算法
//用迭代算法算出第m个值 //1,1,2,3,5,8...; //{1,0+1,1+1,1+2,2+3 ,3+5} static void Main(string[] arg ...
- 美好头标ToolBar
ActionBar我相信是每一位合格的程序员都用过的组件,也是每一个程序员都会抱怨的组件,因为他不能实现复杂的自定义.为此Google推出了比ActionBar更为美好的组件ToolBar. 本文重点 ...