A92145.「CodePlus 2018 3 月赛」寻找车位

省选/NOI-

通过率:0%

时间限制:2.00s

内存限制:1024MB

题目描述

access_globe 有一个巨大的停车场,这个停车场有 nn 行,每行有 mm 个车位。为了美观,access_globe 在建立这个停车场时,规定这个停车场必须是长条形的,即 nmn\ge m。每个车位都是一个正方形的区域。

最近,access_globe 正在为抽不到 Missing Poster 而苦恼,因此他请你帮他维护这个停车场。你需要支持两个事件:

  • 一辆车停到某一个车位中,或一辆车从某个车位开走
  • 查询一个矩形区域内最大的只包含空车位的正方形区域

如果你能帮 access_globe 高效地解决这个问题,access_globe 一定会好好奖励你的。

输入格式

从标准输入读入数据。

第一行包含三个正整数 nnmmqq,表示停车场的大小和事件的个数;

接下来 nn 行,每行 mm 个 0 或 1 的数,如果第 ii 行第 jj 的数11,则表示第 ii 行第 jj 列的车位为空,否则表示这个车位非空

接下来 qq 行,每行表示一个事件,有以下两种形式:

  • 00 xx yy :第 xx 行第 yy 列的车位的停车情况改变,即若此事件发生前这个车位为空,则此事件后这个车位非空,否则此事件后这个车位为空,保证 1xn1\le x\le n1ym1\le y\le m
  • 11 ll ss rr tt:询问以 (l,s)(l, s)(r,t)(r,t) 为对角的矩形区域中,最大的全空正方形区域的边长,保证 1lrn1\le l\le r\le n1stm1\le s\le t\le m

输出格式

输出到标准输出。

对每个询问输出一行一个整数,表示该询问的全空正方形的边长。

输入输出样例

  • 输入#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
    

    输出#1

    2
    1
    0
    1
    1
    1
    1
    1
    

说明/提示

子任务编号 n,mn,m 的额外限制 qq 的额外限制 修改操作 是否保证 s=1,t=ms=1,t=m
1 n,m500n,m\le 500 q500q\le 500 存在
2 m10m\le 10 保证不存在
3 m10m\le 10 存在
4 n40000n\le 40000 保证不存在
5 n40000n\le 40000 存在
6 m10m\le 10 保证不存在
7 m10m\le 10 存在
8 n40000n\le 40000 保证不存在
9 n40000n\le 40000 存在
10 存在

所有子任务的分值均等分布。

对于所有数据,保证 n×m4×106n\times m\le 4 \times 10^{6}q2,000q\le 2,000


来自 CodePlus 2018 3 月赛,清华大学计算机科学与技术系学生算法与竞赛协会 荣誉出品。
Credit:idea/陈俊锟 命题/陈俊锟 验题/吕欣
Git Repo:https://git.thusaac.org/publish/CodePlus3 (链接已失效)
感谢腾讯公司对此次比赛的支持。

首页