[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. VS2017一步一步断点调试解决Dapper语句出现的Bug

    最近再做一个项目,出现一个小bug,bug虽小,但是却要命啊.下面我show下我解决问题的方法. View层代码: @model List<mhq.Blog.Model.Blog> < ...

  2. Socket异步通信及心跳包同时响应逻辑分析(最后附Demo)。

    有段时间没有更博了,刚好最近在做Socket通信的项目,原理大致内容:[二维码-(加logo)]-->提供主机地址和端口号信息(直接使用[ThoughtWorks.QRCode.dll]比较简单 ...

  3. php5.6安装Zend Opcache扩展

    假设php5.6安装路径为/data2/php[root@nextcloud src]# pwd/usr/local/src[root@nextcloud src]# wget http://pecl ...

  4. centos7下部署iptables环境纪录(关闭默认的firewalle)

    CentOS7默认的防火墙不是iptables,而是firewall.由于习惯了用iptables作为防火墙,所以在安装好centos7系统后,会将默认的firewall关闭,并另安装iptables ...

  5. 2-Twenty Fourth Scrum Meeting-20151230

    前言 因为服务器关闭,我们的开发项目也遭遇停滞一个星期.与网站开发负责人员协商之后,29号开放服务器.我们的项目也能够继续下去.比规定的开发时间(截止为2015/12/29)推迟. 事项安排 1.开发 ...

  6. 《Linux课本》读书笔记 第十七章 模块

    设备与模块: 设备类型:块设备(blkdev).字符设备(cdev).网络设备: 模块: 分析hello,world模块代码.Hello_init是模块的入口点,通过module_init()注册到系 ...

  7. struts引入s标签

    <%@ taglib prefix="s" uri="/struts-tags"%>

  8. Java开发异常

    1.org.apache.catalina.LifecycleException 报错信息如下: 警告: Error during context [/wxqhbcloud] restart org. ...

  9. 剑指offer:变态跳台阶

    题目描述 一只青蛙一次可以跳上1级台阶,也可以跳上2级……它也可以跳上n级.求该青蛙跳上一个n级的台阶总共有多少种跳法.   思路 首先想到的解决方案是根据普通跳台阶题目改编,因为可以跳任意级,所以要 ...

  10. MySql连接空闲8小时自动断开引起的问题

    一.问题描述 ​ 最近遇到了一个奇怪的MySql数据库问题,好几次前一天晚上历史数据还正常存储,第二天早上来了看实时数据存储还正常,历史数据不存储了.找了好久也没找到问题.后来仔细想了想,历史数据设置 ...