浅谈树状数组与线段树:https://www.cnblogs.com/AKMer/p/9946944.html

题目传送门:https://www.luogu.org/problemnew/show/P3960

所有出队的人都在第一排的部分分,显然就是维护一条链,支持动态分离出一个数字丢到最后面去,这个部分分提示了正解做法。对于每一行除去最后一个人和最后一列我们分别开一个线段树维护区间内已经有多少数字出队了。那么就有\(n+1\)棵线段树,一个区间还剩多少数字在队内就是\(r-l+1-sum[p]\)。对于每次询问\((x,y)\),答案就是第\(x\)行的第\(y\)个没有出队的数字。我们可以把线段树的范围开到\([1,m+q]\),对于从最后一列向左看齐靠过来的人,我们用一个\(vector\)维护一下就行了。如果第\(y\)个没有出队的数字小于\(m\),那么就是这个人出队,否则就是这个没有出队的数字\(-(m-1)-1\)在\(vector\)里存的数字。最后一列的维护同理。动态开点就不会炸内存了,因为每次最多新建\(logn\)个结点。

时间复杂度:\(O(qlogn)\)

空间复杂度:\(O(nlogn)\)

代码如下:

#include <vector>
#include <cstdio>
using namespace std;
typedef long long ll; const int maxn=6e5+5; int n,m,q,tot;
vector<ll> num[maxn];
int rt[maxn>>1],sum[maxn*20],ls[maxn*20],rs[maxn*20]; int read() {
int x=0,f=1;char ch=getchar();
for(;ch<'0'||ch>'9';ch=getchar())if(ch=='-')f=-1;
for(;ch>='0'&&ch<='9';ch=getchar())x=x*10+ch-'0';
return x*f;
} void updata(int p) {
sum[p]=sum[ls[p]]+sum[rs[p]];
} int find(int &p,int l,int r,int rk) {
if(!p)p=++tot;sum[p]++;//动态开点,用过的数字必然会增加一个,所以就直接一条路径++下来。
if(l==r) return l;
int mid=(l+r)>>1,ans;
if(mid-l+1-sum[ls[p]]>=rk)ans=find(ls[p],l,mid,rk);
else ans=find(rs[p],mid+1,r,rk-(mid-l+1-sum[ls[p]]));//在右儿子里找第(rk-左儿子未出队个数)的数字。
return ans;
} int main() {
n=read(),m=read(),q=read();
for(int i=1;i<=q;i++) {
int x=read(),y=read();
ll lst=find(rt[n+1],1,n+q,x);//找这一排最后一个数字
if(lst<=n)lst=lst*m;
else lst=num[n+1][lst-n-1];//求编号
if(y==m)printf("%lld\n",lst),num[n+1].push_back(lst);//如果就是求最后一个那么只要维护最后一列的线段树就行了。
else {
ll ans=find(rt[x],1,m+q-1,y);
if(ans<m)ans+=1ll*(x-1)*m;
else ans=num[x][ans-m];//找第y个数字
printf("%lld\n",ans);
num[x].push_back(lst);
num[n+1].push_back(ans);//分别向左看齐向前看齐
}
}
return 0;
}

洛谷【P3960】列队的更多相关文章

  1. 洛谷P3960 列队(NOIP2017)(Splay)

    洛谷题目传送门 最弱的Splay...... 暴力模拟30分(NOIP2017实际得分,因为那时连Splay都不会)...... 发现只是一个点从序列里搬到了另一个位置,其它点的相对位置都没变,可以想 ...

  2. 洛谷 P3960 列队 解题报告

    P3960 列队 题目描述 \(Sylvia\)是一个热爱学习的女♂孩子. 前段时间,\(Sylvia\)参加了学校的军训.众所周知,军训的时候需要站方阵. \(Sylvia\)所在的方阵中有\(n ...

  3. 洛谷 P3960 列队

    https://www.luogu.org/problemnew/show/P3960 常数超大的treap #pragma GCC optimize("Ofast") #incl ...

  4. 洛谷P3960 列队 NOIp2017 线段树/树状数组/splay

    正解:动态开点线段树 解题报告: 传送门! 因为最近学主席树的时候顺便get到了动态开点线段树?刚好想起来很久很久以前就想做结果一直麻油做的这题,,,所以就做下好了QAQ 然后说下,这题有很多种方法, ...

  5. 洛谷P3960 列队(动态开节点线段树)

    题意 题目链接 Sol 看不懂splay..,看不懂树状数组... 只会暴力动态开节点线段树 观察之后不难发现,我们对于行和列需要支持的操作都是相同的:找到第\(k\)大的元素并删除,在末尾插入一个元 ...

  6. 洛谷P3960 列队(Splay)

    传送门 感觉自己好久不打数据结构已经完全不会了orz…… 据说正解树状数组?然而并不会 首先考虑一下每一次操作,就是把一个人从这一行中取出并放到行的最后,再从最后一列取出放到列的最后 那么这两种操作其 ...

  7. 洛谷 P3960 列队【线段树】

    用动态开点线段树分别维护每一行和最后一列,线段树的作用是记录被选的点的个数以及查询第k个没被选的点,每次修改,从行里标记被选的点,从最后一列标记向左看齐之后少的点,然后用vector维护行列的新增点 ...

  8. 洛谷P3960 列队 Splay

    其实思路并不算太难,就是代码量相对较大. 我们将一次离队转换为一次删除和两次加入,这样就可以保证空间是动态分配的,最大也不会暴空间. 说实话写之前感觉会很恶心,但是代码量就还好吧,有些细节需要特殊注意 ...

  9. 【洛谷P3960】列队题解

    [洛谷P3960]列队题解 题目链接 题意: Sylvia 是一个热爱学习的女孩子. 前段时间,Sylvia 参加了学校的军训.众所周知,军训的时候需要站方阵. Sylvia 所在的方阵中有 n×m ...

  10. NOIP2017提高组Day2T3 列队 洛谷P3960 线段树

    原文链接https://www.cnblogs.com/zhouzhendong/p/9265380.html 题目传送门 - 洛谷P3960 题目传送门 - LOJ#2319 题目传送门 - Vij ...

随机推荐

  1. PHP中__get()和__set()的用法实例详解

    php面向对象_get(),_set()的用法 一般来说,总是把类的属性定义为private,这更符合现实的逻辑.但是,对属性的读取和赋值操作是非常频繁的,因此在PHP5中,预定义了两个函数“__ge ...

  2. 【NOI2015】【程序自己主动分析】【并查集+离散化】

    Description 在实现程序自己主动分析的过程中,经常须要判定一些约束条件能否被同一时候满足. 考虑一个约束满足问题的简化版本号:如果x1,x2,x3,-代表程序中出现的变量.给定n个形如xi= ...

  3. nagios-plugins安装报错--with-mysql: no

    --with-mysql: no 解决方法 yum安装mysql-devel yum install mysql-devel

  4. cmake是什么

    1 cmake是什么 cmake是一个管理软件build过程的工具.它并不会直接build处软件可执行文件本身,而是build出可以build出软件本身的全部工程文件,比如makefiles.xcod ...

  5. HDFS relaxes a few POSIX requirements to enable streaming access to file system data

    https://hadoop.apache.org/docs/r2.7.2/hadoop-project-dist/hadoop-hdfs/HdfsDesign.html Introduction [ ...

  6. iframe式ajax调用

    1.新建 a.html <!doctype html> <html> <head> <meta charset='utf-8'> <title&g ...

  7. PHP 关于路径的问题

    <?php var_dump(basename(__FILE__)); //返回当前文件/文件夹的的文件名/目录名 var_dump(dirname(__FILE__)); //返回当前文件/文 ...

  8. Flask:工厂函数和蓝本

    我们用pycharm去新建Flask项目的时候,会默认生成开发文件.如下,其中包括static,templates,flask1_prj.py文件 在最初开始的时候,我们的app等声明都是在flask ...

  9. API的理解和使用——哈希类型的命令

    哈希常用的命令复习 命令 功能 hset key field value 设置哈希值 hsetnx 设置哈希值,field或键必须不存在 hget 获取某个file对应的值 hdel 删除一个或多个f ...

  10. Java for LeetCode 119 Pascal's Triangle II

    Given an index k, return the kth row of the Pascal's triangle. For example, given k = 3, Return [1,3 ...