CF 480 E. Parking Lot

http://codeforces.com/contest/480/problem/E

题意:

  给一个n*m的01矩阵,每次可以将一个0修改为1,求最大全0的矩阵。

分析:

  将询问离线,从后往前处理询问,相当于每次将一个1变成0,答案是递增的。

  用悬线法或者单调栈来求。

代码:

 #include<cstdio>
#include<algorithm>
#include<cstring>
#include<cmath>
#include<iostream>
#include<cctype>
#include<set>
#include<vector>
#include<queue>
#include<map>
using namespace std;
typedef long long LL; inline int read() {
int x=,f=;char ch=getchar();for(;!isdigit(ch);ch=getchar())if(ch=='-')f=-;
for(;isdigit(ch);ch=getchar())x=x*+ch-'';return x*f;
} const int N = ; char a[N][N];
int x[N], y[N], L[N], R[N], U[N][N], D[N][N], q1[N], q2[N], ans[N], sk[N];
int Ans, n, m; void solve() {
for (int i=; i<=n; ++i)
for (int j=; j<=m; ++j)
U[i][j] = a[i][j] == '.' ? U[i-][j] + : ;
for (int i=n; i>=; --i)
for (int j=; j<=m; ++j)
D[i][j] = a[i][j] == '.' ? D[i+][j] + : ;
for (int i=; i<=n; ++i) { // 单调栈
U[i][] = U[i][m+] = -;
for (int top=,j=; j<=m+; ++j) {
while (top > && U[i][j] < U[i][sk[top]]) R[sk[top]] = j, top--;
sk[++top] = j;
}
for (int top=,j=m; j>=; --j) {
while (top > && U[i][j] < U[i][sk[top]]) L[sk[top]] = j, top --;
sk[++top] = j;
}
for (int j=; j<=m; ++j)
Ans = max(Ans, min(U[i][j], R[j] - L[j] - ));
}
/*memset(R, 0x3f, sizeof(R)); // 悬线法
for (int i=1; i<=n; ++i) {
int last = 0;
for (int j=1; j<=m; ++j) {
if (a[i][j] == '.') L[j] = max(L[j], last + 1);
else last = j, L[j] = 0;
}
last = m + 1;
for (int j=m; j>=1; --j) {
if (a[i][j] == '.') R[j] = min(R[j], last - 1);
else last = j, R[j] = m + 1;
}
for (int j=1; j<=m; ++j)
Ans = max(Ans, min(U[i][j], R[j] - L[j] + 1));
}*/
}
bool update(int x,int k) { // 判断能否组成k*k的方阵
int L1 = , R1 = , L2 = , R2 = ;
for (int j=; j<=m; ++j) {
while (L1 <= R1 && j - q1[L1] + > k) L1 ++;
while (L1 <= R1 && U[x][q1[R1]] >= U[x][j]) R1 --;
q1[++R1] = j; while (L2 <= R2 && j - q2[L2] + > k) L2 ++;
while (L2 <= R2 && D[x][q2[R2]] >= D[x][j]) R2 --;
q2[++R2] = j; if (j >= k && U[x][q1[L1]] + D[x][q2[L2]] - >= k) {
Ans = k;
return true;
}
}
return false;
}
void Change(int x,int y) {
a[x][y] = '.';
for (int i=x; i<=n; ++i) U[i][y] = a[i][y] == '.' ? U[i-][y] + : ;
for (int i=x; i>=; --i) D[i][y] = a[i][y] == '.' ? D[i+][y] + : ;
}
int main() {
n = read(), m = read(); int Q = read();
for (int i=; i<=n; ++i) scanf("%s",a[i]+);
for (int i=; i<=Q; ++i) {
x[i] = read(),y[i] = read();
a[x[i]][y[i]] = 'X';
}
solve();
for (int i=Q; i>=; --i) {
ans[i] = Ans;
Change(x[i], y[i]);
while (update(x[i], Ans + ));
}
for (int i=; i<=Q; ++i) printf("%d\n",ans[i]);
return ;
}

CF 480 E. Parking Lot的更多相关文章

  1. Codeforces 480.E Parking Lot

    E. Parking Lot time limit per test 3 seconds memory limit per test 256 megabytes input standard inpu ...

  2. 【26.8%】【CF 46D】Parking Lot

    time limit per test 2 seconds memory limit per test 256 megabytes input standard input output standa ...

  3. CF 480 B Long Jumps (map标记)

    题目链接:http://codeforces.com/contest/480/problem/B 题目描述:     Long Jumps   Valery is a PE teacher at a ...

  4. CF数据结构练习

    1. CF 438D The Child and Sequence 大意: n元素序列, m个操作: 1,询问区间和. 2,区间对m取模. 3,单点修改 维护最大值, 取模时暴力对所有>m的数取 ...

  5. ORA-00494: enqueue [CF] held for too long (more than 900 seconds) by 'inst 1, osid 5166'

    凌晨收到同事电话,反馈应用程序访问Oracle数据库时报错,当时现场现象确认: 1. 应用程序访问不了数据库,使用SQL Developer测试发现访问不了数据库.报ORA-12570 TNS:pac ...

  6. cf之路,1,Codeforces Round #345 (Div. 2)

     cf之路,1,Codeforces Round #345 (Div. 2) ps:昨天第一次参加cf比赛,比赛之前为了熟悉下cf比赛题目的难度.所以做了round#345连试试水的深浅.....   ...

  7. cf Round 613

    A.Peter and Snow Blower(计算几何) 给定一个点和一个多边形,求出这个多边形绕这个点旋转一圈后形成的面积.保证这个点不在多边形内. 画个图能明白 这个图形是一个圆环,那么就是这个 ...

  8. ARC下OC对象和CF对象之间的桥接(bridge)

    在开发iOS应用程序时我们有时会用到Core Foundation对象简称CF,例如Core Graphics.Core Text,并且我们可能需要将CF对象和OC对象进行互相转化,我们知道,ARC环 ...

  9. [Recommendation System] 推荐系统之协同过滤(CF)算法详解和实现

    1 集体智慧和协同过滤 1.1 什么是集体智慧(社会计算)? 集体智慧 (Collective Intelligence) 并不是 Web2.0 时代特有的,只是在 Web2.0 时代,大家在 Web ...

随机推荐

  1. [原]零基础学习在Android进行SDL开发后记

    本着学习交流记录的目的编写了这个系列文章,主要用来记录如何从零开始学习SDL开发的过程,在这个过程中遇到了很多问题,差点就放弃了.首先是SDL的Android移植的时候遇到了比较坑的是SDL移植到An ...

  2. canvas的两个方法说明

    今天在用canvas的时候,发现有两个方法比较陌生,在此记录详细说明一下. (1)文本绘制的一个方法 canvas.drawTextOnPath(text, path, hOffset, vOffse ...

  3. LSF作业管理系统使用方法

    查看LSF计算节点列表bhosts # bhosts HOST_NAME STATUS JL/U MAX NJOBS RUN SSUSP USUSP RSV fat01 ok - 16 0 0 0 0 ...

  4. vue - 数据驱动,组件化, 双向绑定原理

    1.数据驱动 传统的前端数据交互是用Ajax从服务端获取数据,然后操作DOM来改变视图: Vue.js 是一个提供了 MVVM 风格的双向数据绑定的 Javascript 库,专注于View 层.它让 ...

  5. JavaScript:回调模式(Callback Pattern) (转载)

    JavaScript:回调模式(Callback Pattern) 函数就是对象,所以他们可以作为一个参数传递给其它函数: 当你将introduceBugs()作为一个参数传递给writeCode() ...

  6. leetcode 78. Subsets 、90. Subsets II

    第一题是输入数组的数值不相同,第二题是输入数组的数值有相同的值,第二题在第一题的基础上需要过滤掉那些相同的数值. level代表的是需要进行选择的数值的位置. 78. Subsets 错误解法: cl ...

  7. x+=i和x = x+i比较 -- 简单赋值和复合赋值

    这两个赋值方式其实是有区别的,如果最后结果的类型和左操作数的类型一样,那么这两个表达式就完全等价. 下面来看看两个例子来理解它们的区别: 编写一个程序,使得x+=i合法, x = x+i: 不合法. ...

  8. css圆角和阴影兼容问题(ie7,ie8)

    <!DOCTYPE html> <html lang="en"> <head> <meta http-equiv="Conten ...

  9. ng2-bootstrap的modal嵌套时无法滚动的情况

    在ng2-bootstrap的弹窗modal中再弹出另外一个弹窗,关闭子弹窗后,父弹窗会出现无法上下滚动的情况. 通过观察样式可知,关闭子弹窗前,父弹窗的body上是有modal-open样式的,关闭 ...

  10. JQuery Ajax 使用FormData上传文件对象

    FormData部分: 先new FormData对象 :let somedata = new FormData(),然后将数据添加进去,这里我们使用append()进行添加. 这里举一个上传头像的例 ...