#P4259. [Code+#3] 寻找车位
[Code+#3] 寻找车位
题目描述
access_globe 有一个巨大的停车场,这个停车场有 行,每行有 个车位。为了美观,access_globe 在建立这个停车场时,规定这个停车场必须是长条形的,即 。每个车位都是一个正方形的区域。
最近,access_globe 正在为抽不到 Missing Poster 而苦恼,因此他请你帮他维护这个停车场。你需要支持两个个事件:
- 一辆车停到某一个车位中,或一辆车从某个车位开走
- 查询一个矩形区域内最大的只包含空车位的正方形区域
如果你能帮 access_globe 高效地解决这个问题,access_globe 一定会好好奖励你的。
输入格式
第一行包含三个正整数 、、,表示停车场的大小和事件的个数;
接下来 行,每行 个 0 或 1 的数,如果第 行第 的数为 ,则表示第 行第 列的车位为空,否则表示这个车位非空;
接下来 行,每行表示一个事件,有以下两种形式:
- :第 行第 列的车位的停车情况改变,即若此事件发生前这个车位为空,则此事件后这个车位非空,否则此事件后这个车位为空,保证 ,
- :询问以 和 为对角的矩形区域中,最大的全空正方形区域的边长,保证 ,
输出格式
对每个询问输出一行一个整数,表示该询问的全空正方形的边长。
5 4 10
1 1 1 0
1 1 1 1
1 1 0 1
1 0 1 0
1 1 0 0
1 1 1 5 4
1 3 1 3 1
1 3 3 3 3
1 2 3 5 3
0 2 2
1 1 4 2 4
1 1 3 3 3
0 5 1
1 2 3 2 4
1 1 2 2 4
2
1
0
1
1
1
1
1
提示
所有子任务的分值均等分布。
对于所有数据,保证 ,。