洛谷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 个和在末尾插入的数据结构 ...
随机推荐
- 基于MongoDB2.6版本配置MongoDB主从复制集群架构
1:集群环境说明:mongodb1:192.168.43.10.mongodb2:192.168.43.11.mongodb3:192.168.43.12.且基于主机名相互通信/etc/hosts文件 ...
- 获取ios设备的udid
今天get的第二个技能~~~ UDID指的是设备的唯一设备识别符,ipa包未上架之前如果不添加udid是无法安装成功的.那么如何快速获取ios设备的udid呢? 今天get的方法是用蒲公英,网址:ht ...
- 10th 本周工作量及进度统计
本周PSP C(类别) C(内容) S(开始时间) ST(结束时间) I(中断时间) T(实际时间) 文档 11月22日 规格说明书练习 10:23 15:30 132 175 11月23日 知识点 ...
- Js apply方法详解,及其apply()方法的妙用
Js apply方法详解 我在一开始看到javascript的函数apply和call时,非常的模糊,看也看不懂,最近在网上看到一些文章对apply方法和call的一些示例,总算是看的有点眉目了,在这 ...
- 开发 | 如何在微信小程序的页面间传递数据?
我们在之前发布过小程序页面传值方法的简单介绍,说明了在小程序开发中,两种常见的页面之间传值方法. 本期,知晓程序(微信号 zxcx0101)为你带来的是「倒数记日」小程序开发者带来的,小程序开发中,有 ...
- pygame学习笔记(1)——安装及矩形、圆型画图
pygame是一个设计用来开发游戏的python模块,其实说白了和time.os.sys都是一样的东东.今天开始正式学习pygame,下载地址:www.pygame.org.下载后安装完成即可,在py ...
- mysql 函数示例(转)
MySQL函数大全及用法示例 1.字符串函数ascii(str) 返回字符串str的第一个字符的ascii值(str是空串时返回0) mysql> select ascii('2'); ...
- 一些基于jQuery开发的控件
基于jQuery开发,非常简单的水平方向折叠控件.主页:http://letmehaveblog.blogspot.com/2007/10/haccordion-simple-horizontal-a ...
- CF1083C Max Mex 线段树
题面 CF1083C Max Mex 题解 首先我们考虑,如果一个数x是某条路径上的mex,那么这个数要满足什么条件? 1 ~ x - 1的数都必须出现过. x必须没出现过. 现在我们要最大化x,那么 ...
- 解题:洛谷2093 JZPFAR
题面 初见K-D Tree 其实这样的题(欧几里得距离第$x$近点对)不应该用K-D Tree做,因为会被构造数据卡成$O(n^2)$,随机的另说. 但是并没有找到合适的K-D Tree的题(区域统计 ...