[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. 扩展ASP.NET Identity使用Int做主键

    当我们默认新建一个ASP.NET MVC项目的时候,使用的身份认证系统是ASP.NET Identity.但是这里的Identity使用的主键为String类型的GUID.当然这是大多数系统首先类型. ...

  2. js类型----你所不知道的JavaScript系列(5)

    ECMAScirpt 变量有两种不同的数据类型:基本类型,引用类型.也有其他的叫法,比如原始类型和对象类型等. 1.内置类型 JavaScript 有七种内置类型: • 空值(null) • 未定义( ...

  3. 为小米(红米)6A解锁_ROOT_安装天下游虚拟定位教程_已亲身验证通过!附图

    第一步骤: 把TeamViewer发给客户 第二步骤: 在自己电脑上购买小米账号:http://shop1.91kami.com/UXWHTEY9KN?cid=1200 要求:(购买邮箱注册账号,需要 ...

  4. Html5计算MD5值

    教程: http://www.tuicool.com/articles/InEBNz 组件: https://github.com/satazor/js-spark-md5

  5. 四则运算C语言程序

    #include<stdio.h> #include<Windows.h> #include<time.h> void main() { int a, b, c, ...

  6. 《Metasploit渗透测试魔鬼训练营》第一章读书笔记

    第1章 魔鬼训练营--初识Metasploit 20135301 1.1 什么是渗透测试 1.1.1 渗透测试的起源与定义 如果大家对军事感兴趣,会知道各国军队每年都会组织一些军事演习来锻炼军队的攻防 ...

  7. 《Linux课本》读书笔记 第四章

  8. 『编程题全队』Beata阶段项目复审

    小组的名字和链接 优点 缺点,bug 报告(部分包括建议) 最终名次 想不出队名 1. 界面简洁大方2. 有搜索功能 1. 已经完成的活动缺了点提示界面2. 似乎界面有一点点卡顿目标实现:基本实现找到 ...

  9. about use Vue of methods

    methods 处理事件 methods 在vue中处理一些逻辑方面的事情.vue事件监听的方式看上去有点违背分离的传统观念.而实际上vue中所有事件的处理方式和表达式都是严格绑定在当前的视图的vie ...

  10. [转自知乎]飞腾国产CPU的部分知识

    1. 作者:常成链接:https://www.zhihu.com/question/48948852/answer/113595308来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商业转载 ...