[cf1379F]Chess Strikes Back
考虑将$(2i-1,2j-1)$和$(2i,2j)$缩为一个点,记作$(i,j)$
对于每一个点,只能选$(2i-1,2j-1)$或$(2i,2j)$(显然不能都选),而这样恰好为$nm$个,因此必须要至少选择一个
对于每一个点,障碍的状态分为以下几类:
1.无障碍,这类点暂时不考虑
2.都有障碍,若存在此类点必然不合法
3.有一个障碍,分两类讨论:
(1)$(2i-1,2j-1)$上有障碍,即这个点只能选$(2i,2j)$,考虑$(i+1,j)$和$(i,j+1)$,也只能选这个点,因此即对于其右下角的点,都要选$(2i,2j)$;
(2)$(2i,2j)$上有障碍,类似的,对于其左上角的点,都要选$(2i-1,2j-1)$
矛盾在于存在一个点$(i_{1},j_{1})$在$(2i_{1}-1,2j_{1}-1)$上有障碍,$(i_{2},j_{2})$在$(2i_{2},2j_{2})$上有障碍,且满足$i_{1}\le i_{2}$、$j_{1}\le j_{2}$,那么对于$([i_{1},i_{2}],[j_{1},j_{2}])$这个矩形就无解了
(其实第2类也可以看作此类情况,即$i_{1}=i_{2}$且$j_{1}=j_{2}$)
通过set,可以求出对于所有$i$,在$(2i-1,2j-1)$上有障碍的最小的$j$和在$(2i,2j)$上有障碍的最大的$j$
对于插入可以很好的支持,即判断新来的点是否会产生即可(通过线段树维护第一个前缀最小值以及第二个后缀最大值),那么删除通过线段树分治即可


1 #include<bits/stdc++.h>
2 using namespace std;
3 #define N 200005
4 #define L (k<<1)
5 #define R (L+1)
6 #define mid (l+r>>1)
7 #define pii pair<int,int>
8 #define mp make_pair
9 #define fi first
10 #define se second
11 map<int,int>mat[N<<1];
12 map<int,int>::iterator it;
13 multiset<int>s1[N],s2[N];
14 vector<pii>v[N<<2];
15 pii f[N<<2];
16 int n,m,q,x,y,ans[N];
17 void add(int k,int l,int r,int x,int y,pii z){
18 if ((l>y)||(x>r))return;
19 if ((x<=l)&&(r<=y)){
20 v[k].push_back(z);
21 return;
22 }
23 add(L,l,mid,x,y,z);
24 add(R,mid+1,r,x,y,z);
25 }
26 pii merge(pii x,pii y){
27 return mp(min(x.fi,y.fi),max(x.se,y.se));
28 }
29 pii get(int k){
30 int x=m+1,y=0;
31 if (s1[k].size())x=(*s1[k].begin());
32 if (s2[k].size())y=(*--s2[k].end());
33 return mp(x,y);
34 }
35 void update(int k,int l,int r,int x){
36 if (l==r){
37 f[k]=get(x);
38 return;
39 }
40 if (x<=mid)update(L,l,mid,x);
41 else update(R,mid+1,r,x);
42 f[k]=merge(f[L],f[R]);
43 }
44 pii query(int k,int l,int r,int x,int y){
45 if ((l>y)||(x>r))return mp(m+1,0);
46 if ((x<=l)&&(r<=y))return f[k];
47 return merge(query(L,l,mid,x,y),query(R,mid+1,r,x,y));
48 }
49 void dfs(int k,int l,int r){
50 if (!ans[0])return;
51 for(int i=0;i<v[k].size();i++){
52 x=v[k][i].fi,y=v[k][i].se;
53 if (y&1){
54 s1[(x+1)/2].insert((y+1)/2);
55 if (query(1,1,n,(x+1)/2,n).se>=(*s1[(x+1)/2].begin()))ans[0]=0;
56 }
57 else{
58 s2[x/2].insert(y/2);
59 if (query(1,1,n,1,x/2).fi<=(*--s2[x/2].end()))ans[0]=0;
60 }
61 update(1,1,n,(x+1)/2);
62 }
63 if (l==r)ans[l]=ans[0];
64 else{
65 dfs(L,l,mid);
66 dfs(R,mid+1,r);
67 }
68 for(int i=0;i<v[k].size();i++){
69 x=v[k][i].fi,y=v[k][i].se;
70 if (y&1)s1[(x+1)/2].erase(s1[(x+1)/2].find((y+1)/2));
71 else s2[x/2].erase(s2[x/2].find(y/2));
72 update(1,1,n,(x+1)/2);
73 }
74 ans[0]=1;
75 }
76 int main(){
77 scanf("%d%d%d",&n,&m,&q);
78 for(int i=1;i<=q;i++){
79 scanf("%d%d",&x,&y);
80 if (!mat[x][y])mat[x][y]=i;
81 else{
82 add(1,1,q,mat[x][y],i-1,mp(x,y));
83 mat[x][y]=0;
84 }
85 }
86 for(int i=1;i<=2*n;i++)
87 for(it=mat[i].begin();it!=mat[i].end();it++)
88 if ((*it).se)add(1,1,q,(*it).se,q,mp(i,(*it).fi));
89 for(int i=1;i<=n;i++)update(1,1,n,i);
90 ans[0]=1;
91 dfs(1,1,q);
92 for(int i=1;i<=q;i++)
93 if (ans[i])printf("YES\n");
94 else printf("NO\n");
95 }
[cf1379F]Chess Strikes Back的更多相关文章
- hdu4405 Aeroplane chess
Aeroplane chess Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)T ...
- HDU 5742 Chess SG函数博弈
Chess Problem Description Alice and Bob are playing a special chess game on an n × 20 chessboard. ...
- POJ2425 A Chess Game[博弈论 SG函数]
A Chess Game Time Limit: 3000MS Memory Limit: 65536K Total Submissions: 3917 Accepted: 1596 Desc ...
- HDU 4832 Chess (DP)
Chess Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submi ...
- 2016暑假多校联合---A Simple Chess
2016暑假多校联合---A Simple Chess Problem Description There is a n×m board, a chess want to go to the po ...
- HDU5724 Chess(SG定理)
题目 Source http://acm.hdu.edu.cn/showproblem.php?pid=5724 Description Alice and Bob are playing a spe ...
- BFS AOJ 0558 Chess
AOJ 0558 Chess http://judge.u-aizu.ac.jp/onlinejudge/description.jsp?id=0558 在H * W的地图上有N个奶酪工厂,每个 ...
- SGU 319. Kalevich Strikes Back (线段树)
319. Kalevich Strikes Back Time limit per test: 0.5 second(s)Memory limit: 65536 kilobytes input: st ...
- Codeforces Round #379 (Div. 2) D. Anton and Chess 水题
D. Anton and Chess 题目连接: http://codeforces.com/contest/734/problem/D Description Anton likes to play ...
随机推荐
- JOIN US | SphereEx 精英集结
新环境.新气象,SphereEx 欢迎志同道合的你加入! 关于 SphereEx 北京思斐软件技术有限公司(sphere-ex.com),是一家致力于构建新型分布式数据基础设施的公司,秉承开源.共享. ...
- Parcel Fabric Tools(宗地结构工具)
宗地结构工具 1.图层和表视图 # Process: 创建宗地结构图层 arcpy.MakeParcelFabricLayer_fabric("", 输出图层) # Process ...
- 洛谷3176 [HAOI2015]数字串拆分 (矩阵乘法+dp)
qwq真的是一道好题qwq自己做基本是必不可能做出来的. 首先,如果这个题目只是求一个\(f\)数组的话,那就是一道裸题. 首先,根据样例 根据题目描述,我们能发现其实同样数字的不同排列,也是属于不同 ...
- PAT (Basic Level) Practice (中文)1009 说反话 (20分)
给定一句英语,要求你编写程序,将句中所有单词的顺序颠倒输出. 输入格式: 测试输入包含一个测试用例,在一行内给出总长度不超过 80 的字符串.字符串由若干单词和若干空格组成,其中单词是由英文字母(大小 ...
- NX屏蔽窗口的按钮
有时候在激活一个命令按钮的时候,需要同时禁止掉另外一个或多个命令按钮 ''' <summary> ''' 取按钮是否敏感 ''' </summary> ''' <para ...
- (半课内)信安数基 RSA-OAEP 初探
在RSA攻击中,存在着"小明文攻击"的方式: 在明文够小时,密文也够小,直接开e次方即可: 在明文有点小时,如果e也较小,可用pow(m,e)=n*k+c穷举k尝试爆破 所以,比如 ...
- activiti流程图上获取各节点的信息获取
背景: 由于项目的需要,当用户在查看流程图时,当点击某个流程图片上的节点时,需要提示一些信息,这就需要获取各个节点的信息,此处获取id和name的值. 注意:这个并 ...
- Stack2 攻防世界题目分析
---XCTF 4th-QCTF-2018 前言,怎么说呢,这题目还是把我折磨的可以的,我一开始是没有看到后面的直接狙击的,只能说呢. 我的不经意间的粗心,破坏了你许多的温柔 1.气的我直接检查保护: ...
- STM32核心板焊接
焊接工具和材料 电烙铁及烙铁头介绍 电烙铁有很多种,常用的有内热式.外热式.恒温式和吸锡式,为了方便携带,建议使内热式电烙铁,且要带烙铁架和海绵,烙铁架用于放置电烙铁,海绵用于擦拭烙铁锡渣,因此海绵不 ...
- DH密钥交换
DH密钥交换 密模运算 所谓幂模,就是先做一次幂运算,再做一次模运算. 模运算有以下性质: 也就是说,先模再乘和先乘再模,只要最后都模了同一个模数,结果都是一样. 有了这个性质,我们首先得到幂模运算的 ...