[IOI2018] seats 排座位

IOI2018题解

压缩状态思想很不错的

每次把原来的贡献减掉,新来的再加上

最多涉及10个点

注意:

1.去重

2.下标从0开始

3.线段树初始的最小值个数都是r-l+1

代码:

#include<bits/stdc++.h>
#define reg register int
#define il inline
#define mid ((l+r)>>1)
#define numb (ch^'0')
using namespace std;
typedef long long ll;
il void rd(int &x){
char ch;x=;bool fl=false;
while(!isdigit(ch=getchar()))(ch=='-')&&(fl=true);
for(x=numb;isdigit(ch=getchar());x=x*+numb);
(fl==true)&&(x=-x);
}
namespace Miracle{
const int N=+;
const int inf=0x3f3f3f3f;
int id[N],vis[N],sta[N],top;
int pos[N][];
int n,m,q;
int num(int x,int y){
return (x-)*m+y;
}
struct tr{
int mi,cnt;
int mx;
int ad;
}t[*N];
void pushup(int x){
t[x].mi=min(t[x<<].mi,t[x<<|].mi);
t[x].mx=max(t[x<<].mx,t[x<<|].mx);
t[x].cnt=t[x<<].cnt*(t[x<<].mi==t[x].mi)+t[x<<|].cnt*(t[x<<|].mi==t[x].mi);
}
void pushdown(int x){
if(!t[x].ad) return;
t[x<<].ad+=t[x].ad;
t[x<<].mi+=t[x].ad;
t[x<<].mx+=t[x].ad;
t[x<<|].ad+=t[x].ad;
t[x<<|].mi+=t[x].ad;
t[x<<|].mx+=t[x].ad; t[x].ad=;
}
void build(int x,int l,int r){
if(l==r){
t[x].cnt=;return;
}
build(x<<,l,mid);
build(x<<|,mid+,r);
pushup(x);
}
void add(int x,int l,int r,int L,int R,int c){
if(L<=l&&r<=R){
t[x].ad+=c;
t[x].mi+=c;
t[x].mx+=c;
if(t[x].mi==t[x].mx) t[x].cnt=r-l+;
return;
}
pushdown(x);
if(L<=mid) add(x<<,l,mid,L,R,c);
if(mid<R) add(x<<|,mid+,r,L,R,c);
pushup(x);
}
int mv[][]={{+,},{-,},{,+},{,-}};
void wrk1(int x,int y,int c){
//cout<<" x y "<<x<<" "<<y<<" c "<<c<<endl;
int mi=inf,cmi=inf;
for(reg i=;i<;++i){
int dx=x+mv[i][],dy=y+mv[i][];
if(dx>=&&dx<=n&&dy>=&&dy<=m){
if(id[num(dx,dy)]<mi){
cmi=mi;mi=id[num(dx,dy)];
}else cmi=min(cmi,id[num(dx,dy)]);
}
} if(cmi<=id[num(x,y)]-) {
//cout<<" x y "<<x<<" "<<y<<" : "<<mi<<" "<<cmi<<endl;
add(,,n*m,cmi,id[num(x,y)]-,c);
}
}
void wrk2(int x,int y,int c){
int mi=n*m+;
int dx=x-,dy=y;
if(dx>=&&dx<=n&&dy>=&&dy<=m){
mi=min(mi,id[num(dx,dy)]);
}
dx=x,dy=y-;
if(dx>=&&dx<=n&&dy>=&&dy<=m){
mi=min(mi,id[num(dx,dy)]);
}
//cout<<" x y "<<x<<" "<<y<<" mimimi "<<mi<<endl;
if(id[num(x,y)]<=mi-) add(,,n*m,id[num(x,y)],mi-,c);
}
void sol(int x,int y,int c){
//cout<<" sol "<<x<<" "<<y<<" c "<<c<<endl;
if(!vis[num(x,y)]) {
sta[++top]=num(x,y);
vis[num(x,y)]=;
wrk1(x,y,c);wrk2(x,y,c);
}
for(reg i=;i<;++i){
int dx=x+mv[i][],dy=y+mv[i][];
if(dx>=&&dx<=n&&dy>=&&dy<=m&&!vis[num(dx,dy)]){
vis[num(dx,dy)]=;
sta[++top]=num(dx,dy);
wrk1(dx,dy,c);wrk2(dx,dy,c);
}
}
}
int main(){
rd(n);rd(m);rd(q);
build(,,n*m);
int x,y;
for(reg i=;i<=n*m;++i){
rd(x);rd(y);
++x;++y;
pos[i][]=x;pos[i][]=y;
id[num(x,y)]=i;
}
for(reg i=;i<=n;++i){
for(reg j=;j<=m;++j){
wrk1(i,j,);
wrk2(i,j,);
}
}
//cout<<t[1].mi<<" "<<t[1].mx<<" "<<t[1].cnt<<endl;
int A,B;
while(q--){
rd(A);rd(B);
++A;++B;
top=; x=pos[A][],y=pos[A][];
sol(x,y,-);
x=pos[B][],y=pos[B][];
sol(x,y,-); while(top) vis[sta[top--]]=;
swap(id[num(pos[A][],pos[A][])],id[num(pos[B][],pos[B][])]);
swap(pos[A][],pos[B][]);
swap(pos[A][],pos[B][]); x=pos[A][],y=pos[A][];
sol(x,y,);
x=pos[B][],y=pos[B][];
sol(x,y,); while(top) vis[sta[top--]]=; int ans=;
if(t[].mi==) ans=t[].cnt;
printf("%d\n",ans);
}
return ;
} }
signed main(){
Miracle::main();
return ;
} /*
Author: *Miracle*
Date: 2019/2/10 17:53:31
*/

[IOI2018] seats 排座位的更多相关文章

  1. 团体程序设计天梯赛-练习集L2-010. 排座位

    L2-010. 排座位 时间限制 150 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 陈越 布置宴席最微妙的事情,就是给前来参宴的各位宾客安排座位. ...

  2. L2-010. 排座位

    L2-010. 排座位 题目链接:https://www.patest.cn/contests/gplt/L2-010 并查集 相关题目:L2-007. 家庭房产,L3-003. 社交集群 下午打的时 ...

  3. L2-010. 排座位(并查集)*

    L2-010. 排座位 参考博客 #include<iostream> #include<math.h> using namespace std; ]; ][]; int fi ...

  4. pta l2-10(排座位)

    题目链接:https://pintia.cn/problem-sets/994805046380707840/problems/994805066135879680 题意:给宴席排座位,有n个人,m个 ...

  5. CCCC 排座位 图着色问题

    1排座位:https://www.patest.cn/contests/gplt/L2-010 2图着色问题 https://www.patest.cn/contests/gplt/L2-023 建图 ...

  6. 排座位&&Little Elephant And Permutation——排列dp的处理

    排列的问题,就是要把序列排个序,使之达到某种最优值或者统计方案数 dp可以解决部分排列问题. 通常的解决方案是,按照编号(优先级)排序决策,从左到右决策两种. 这里主要是第一个. 排座位• 有

  7. pat 团体天梯赛 L2-010. 排座位

    L2-010. 排座位 时间限制 150 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 陈越 布置宴席最微妙的事情,就是给前来参宴的各位宾客安排座位. ...

  8. CCCC L2-010. 排座位【并查集/分类讨论】

    L2-010. 排座位 时间限制 150 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 陈越 布置宴席最微妙的事情,就是给前来参宴的各位宾客安排座位. ...

  9. 天梯杯 L2-010. 排座位

    L2-010. 排座位 时间限制 150 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 陈越 布置宴席最微妙的事情,就是给前来参宴的各位宾客安排座位. ...

随机推荐

  1. 懒人小工具1:winform自动生成Model,Insert,Select,Delete以及导出Excel的方法

       懒人小工具2:T4自动生成Model,Insert,Select,Delete以及导出Excel的方法    github地址:https://github.com/Jimmey-Jiang/J ...

  2. visual studio 2013的使用和单元测试

    Visual Studio 2013 是一个先进的开发解决方案,各种规模的团队通过它均可设计和创建引人注目的应用程序.Visual Studio 13在新功能包括C#和VB编译器和IDE支持完全基于. ...

  3. Bing词典分析

    0x01 Bug测试结果 本次测试的是Bing词典wp版本V4.5.2,经过测试,共发现如下Bug. 1.更新后,旧版本首页的每日单词与文章推荐不能重新获得,部分搜索历史记录丢失. 2.在单词挑战模式 ...

  4. Cocos2d-x项目创建方式

    刚接触cocos2d-x的时候,还只有2.x版本,尝试着将cocos2d-x项目创建功能加入到vs里面去,后来,引擎用Python封装好了好多个脚本文件,其中就包括create_project.py文 ...

  5. mybatis中批量更新的问题

    问题:使用mybatis在执批量更新操作时,一直报错执行失败 解决方法: 首先打印了SQL语句,发现SQL语句拿出来执行没问题,也可以批量执行.SQL没问题,应该是配置的问题. 在网上查询和很多资料, ...

  6. 9-Python3从入门到实战—基础之条件控制语句

    Python从入门到实战系列--目录 条件判断 if 条件判断 if 语句语法 if <条件判断1>: <执行1> elif <条件判断2>: <执行2> ...

  7. ACL访问控制

    /etc/squid/squid.conf 定义语法: acl aclname  acltype   string acl  aclname  acltype   "file" s ...

  8. SQLSERVER 创建对Oracle数据库的DBlink以及查询使用

    1. 与针对oracle数据库一样, 在sqlserver中创建对oracle数据库的dblink 安全性上面也进行定义(貌似不需要跟访问字符串只需要填一个即可) 发现有的版本改注册表不管用 还得修改 ...

  9. ESXi安装时遇到不识别的硬件的处理

    1. 部门新购置了一台inspur 四路 NF8480M4的服务器. 上架之后发现ESXi的标准安装盘无法安装. 找不到磁盘安装介质. 2. 处理办法, 找浪潮专家服务,报上序列号,要上相关的一些软件 ...

  10. linux shell << 注释多行

    #!/bin/bash #script name: a.sh #author: aaron <<EOF echo "line 1" echo "line 2& ...