洛谷P3960 [NOIP2017] 列队
数据结构题还是挺好玩的
注意到每次只变动三个点:(x,y),(x,m),(n,m),其他地方都是整块移动。
可以开n+1个线段树,前n个存每行前m-1个人,最后一个存第m列的人。
(x,y)位置的人出列时,抽出该位置的标号,加到第n+1个线段树的最后面去,抽出第n+1个线段树的第x个元素(即(x,m),加到第x个线段树的最后面去。
↑实现这一操作,可以记线段树的size,每次二分查询树上第k个元素即可确定位置。
↑当然树不可能全建出来,需要动态开点。尚未申请的结点,size直接用$ r-l+1 $计算。
写到一半想到不需要专门抽出来,只需要记录该行到该位置为止抽出过a个数,找(x,y)时实际找(x,y+a)即可。可以开个vector什么的存新加到队伍最右边的人。
这样的话更加方便&优美,而且可以用树状数组写,代码量也减小了。
但是看着自己写了一大半的代码不舍得丢,还是强行按原计划敲完了。
————
老年退役选手连NOIP题都做不来了。做这题成功遇到了数组开小,变量写混,初始化错误,输出错误等等问题,调了好久。
不开心QAQ
————
#include<iostream>
#include<cstdio>
#define LL long long
using namespace std;
const int mxn=;
struct node{
int sz,lc,rc;
LL mk;
}t[mxn<<];
int cnt=,mod=;
int root[mxn];
int n,N,m,Q;
inline int getsz(int l,int r,int rt){
if(rt)return t[rt].sz;
return r-l+;
}
void pushup(int l,int r,int rt){
int tmp=;
int mid=(l+r)>>;
tmp+=getsz(l,mid,t[rt].lc);
tmp+=getsz(mid+,r,t[rt].rc);
t[rt].sz=tmp;
return;
}
int anspos;
int query(int k,int l,int r,int &rt){
if(!rt){
rt=++cnt;
t[rt].sz=r-l+;
}
if(l==r){
if(!t[rt].mk){//计算标号
if(mod==n+)t[rt].mk=(LL)l*m;
else t[rt].mk=(LL)(mod-)*m+l;
}
anspos=l;
return rt;
}
int mid=(l+r)>>,tmp=getsz(l,mid,t[rt].lc);
if(k<=tmp)
return query(k,l,mid,t[rt].lc);
else return query(k-tmp,mid+,r,t[rt].rc);
}
void update(LL v,int p,int l,int r,int &rt){
if(!rt){
rt=++cnt;
t[rt].sz=r-l+;
}
if(l==r){
t[rt].mk=v;
if(!v){//del
t[rt].sz=;
}
else t[rt].sz=;
return;
}
int mid=(l+r)>>;
if(p<=mid)update(v,p,l,mid,t[rt].lc);
else update(v,p,mid+,r,t[rt].rc);
pushup(l,r,rt);
return;
}
void info(int l,int r,int rt){
printf(" %d %d rt:%d sz:%d\n",l,r,rt,getsz(l,r,rt));
if(!rt)return;
if(l==r)return;
int mid=(l+r)>>;
info(l,mid,t[rt].lc);
info(mid+,r,t[rt].rc);
return;
}
int main(){
// freopen("2017phalanx.in","r",stdin);
// freopen("2017phalanx.out","w",stdout);
int i,j,x,y,tmp;
LL tmp2;
scanf("%d%d%d",&n,&m,&Q);
N=max(max(n,m),Q)<<;
while(Q--){
scanf("%d%d",&x,&y);
if(y==m){
mod=n+;
tmp=query(x,,N,root[n+]);
tmp2=t[tmp].mk;
printf("%lld\n",t[tmp].mk);
update(,anspos,,N,root[n+]);
tmp=query(n,,N,root[n+]);
update(tmp2,anspos,,N,root[n+]);
}
else{
// printf(" in\n");
mod=x;
tmp=query(y,,N,root[x]);
tmp2=t[tmp].mk;
printf("%lld\n",t[tmp].mk);
update(,anspos,,N,root[x]);//出队
// printf("anspos:%d\n",anspos);
//
mod=n+;
tmp=query(n+,,N,root[n+]);
update(tmp2,anspos,,N,root[n+]);
// printf("UPD: mk:%d pos:%d\n",tmp2,anspos);
//
tmp=query(x,,N,root[n+]);
tmp2=t[tmp].mk;
// printf("bu:%d anspos:%d\n",tmp2,anspos);
update(,anspos,,N,root[n+]);
mod=x;
tmp=query(m-,,N,root[x]);
update(tmp2,anspos,,N,root[x]);
//
}
// info(1,N,root[n+1]);
}
return ;
}
洛谷P3960 [NOIP2017] 列队的更多相关文章
- 【洛谷P3960】列队题解
[洛谷P3960]列队题解 题目链接 题意: Sylvia 是一个热爱学习的女孩子. 前段时间,Sylvia 参加了学校的军训.众所周知,军训的时候需要站方阵. Sylvia 所在的方阵中有 n×m ...
- NOIP2017提高组Day2T3 列队 洛谷P3960 线段树
原文链接https://www.cnblogs.com/zhouzhendong/p/9265380.html 题目传送门 - 洛谷P3960 题目传送门 - LOJ#2319 题目传送门 - Vij ...
- 洛谷P3960 列队(NOIP2017)(Splay)
洛谷题目传送门 最弱的Splay...... 暴力模拟30分(NOIP2017实际得分,因为那时连Splay都不会)...... 发现只是一个点从序列里搬到了另一个位置,其它点的相对位置都没变,可以想 ...
- 洛谷P3959 [NOIP2017]宝藏
[题目描述] 参与考古挖掘的小明得到了一份藏宝图,藏宝图上标出了 n 个深埋在地下的宝藏屋,也给出了这 n 个宝藏屋之间可供开发的 m 条道路和它们的长度. 小明决心亲自前往挖掘所有宝藏屋中的宝藏.但 ...
- 洛谷P4559 [JSOI2018]列队 【70分二分 + 主席树】
题目链接 洛谷P4559 题解 只会做\(70\)分的\(O(nlog^2n)\) 如果本来就在区间内的人是不用动的,区间右边的人往区间最右的那些空位跑,区间左边的人往区间最左的那些空位跑 找到这些空 ...
- 洛谷P3960 列队 NOIp2017 线段树/树状数组/splay
正解:动态开点线段树 解题报告: 传送门! 因为最近学主席树的时候顺便get到了动态开点线段树?刚好想起来很久很久以前就想做结果一直麻油做的这题,,,所以就做下好了QAQ 然后说下,这题有很多种方法, ...
- 洛谷 P3960 列队 解题报告
P3960 列队 题目描述 \(Sylvia\)是一个热爱学习的女♂孩子. 前段时间,\(Sylvia\)参加了学校的军训.众所周知,军训的时候需要站方阵. \(Sylvia\)所在的方阵中有\(n ...
- 洛谷 P3960 列队
https://www.luogu.org/problemnew/show/P3960 常数超大的treap #pragma GCC optimize("Ofast") #incl ...
- 洛谷 P3960 [ NOIP 2017 ] 列队 —— 线段树
题目:https://www.luogu.org/problemnew/show/P3960 NOIP 题,不用很复杂的数据结构...但又参考了许多: 要求支持维护删除第 k 个和在末尾插入的数据结构 ...
随机推荐
- PAT 甲级 1151 LCA in a Binary Tree
https://pintia.cn/problem-sets/994805342720868352/problems/1038430130011897856 The lowest common anc ...
- 利用ceye中的dns来获取数据
安恒杯的一道命令执行题目 查看,存在robots.txt文件 查看index.txt文件,存在where_is_flag.php文件 使用cat没有任何回显 可以使用ceye平台利用dns记录内容,网 ...
- android自动化之appium的环境搭建
简介appium appium是C/S架构,appium的核心是一个web服务器,它提供了一套REST的接口,他会接收客户端的连接,监听到命令.执行会再将结果通过HTTP响应返还给客户端.ap ...
- d指针在Qt上的应用及实现(有图,很清楚)
Qt为了使其动态库最大程度上实现二进制兼容,引入了d指针的概念.那么为什么d指针能实现二进制兼容呢?为了回答这个问题,首先弄清楚什么是二进制兼容?所谓二进制兼容动态库,指的是一个在老版本库下运行的程序 ...
- MySQL复合主键下ON DUPLICATE KEY UPDATE语句失效问题
问题的起因,假设有一张表,里面保存了交易订单,每张订单有唯一的ID,有最后更新时间,还有数据,详情如下: 1 2 3 4 5 6 7 +-------+----------+------+-----+ ...
- UVA11374_Airport Express
给一个无向图,有的边是特殊边,最多可以取一条特殊边,求最短路,并且输出路径. 这样考虑,加入所有非特殊边,求出每个点到起点和终点的最短路.然后加入特殊边的时候,如果取当前这条特殊边,那么答案会是两点预 ...
- iOS 数据库sqlite完整增删改查操作
1: 创建数据库表格 1.1 — 表格创建使用一个数据库软件快速创建:软件大小14.3M; 下载地址:http://pan.baidu.com/s/1qWOgGoc; 表格创建-> 打开软件,点 ...
- 修改pip源到国内的镜像源
国内网络原因,经常无法访问一些技术网站,pypi.python.org就是其中一个.所以,使用pip给Python安装软件时,经常出现错误.like this: File "/usr/lib ...
- python selenium2 定位一组元素find_elements实例
打开hao123首页,需要定位以上区域中的所有链接,他们有相同的父元素<ul class="js_bd site-bd site-hd0">,所有链接处在li>a ...
- 使用IDEA远程部署tomcat和调试
环境: CentOS 7 Tomcat 9.0.1 jdk-9.0.1 IntelliJ IDEA 2017.3 Tomcat中的配置 在catalina.sh文件中加入以下的配置 CATALINA_ ...