题目描述(口糊)

先给定一个长度为n的数列,然后给m次操作,每次输入b,求第b小的数。

样例输入

5
7 4 10 9 23
5
1
2
3
4
5

样例输出

4
7
9
10
23

数据范围及温馨提示

1e9 大家一定要用线段树做这道题啊!

建议大家在认真阅读一下逆序对的题解

题解传送门

于是这里我们只需要把query改一下其实就可以了。

int query(int k,int cnt)
{
if(node[k].l==node[k].r) return node[k].l;
if(cnt<=node[node[k].son[0]].cnt) return query(node[k].son[0],cnt);
else return query(node[k].son[1],cnt-node[node[k].son[0]].cnt);
}

其他都一样,我用的是动态开点。

整体代码如下:

#include<bits/stdc++.h>
using namespace std;
const int N=1000005;
struct sd{
int son[2];
long long l,r,cnt;
}node[N];
int n;
int cnt=1;
long long ans;
void update(int k)
{
node[k].cnt=node[node[k].son[0]].cnt+node[node[k].son[1]].cnt;
}
void modify(int k,int val)
{
if(node[k].l==node[k].r&&node[k].l==val)
{
node[k].cnt++;
return;
}
int mid=node[k].l+node[k].r;mid/=2;
if(node[k].son[0]==0)
{
cnt++;
node[k].son[0]=cnt;
node[cnt].l=node[k].l;node[cnt].r=mid;
}
if(node[k].son[1]==0)
{
cnt++;
node[k].son[1]=cnt;
node[cnt].l=mid+1;node[cnt].r=node[k].r;
}
if(val>mid)
{
modify(node[k].son[1],val);
}
else
{
modify(node[k].son[0],val);
}
update(k);
}
/*long long query(int k,int ql,int qr)
{
if(k==0) return 0;
if(node[k].l==ql&&node[k].r==qr)
{
return node[k].cnt;
}
else
{
int mid=(node[k].l+node[k].r)/2;
if(qr<=mid) return query(node[k].son[0],ql,qr);
else if(ql>mid) return query(node[k].son[1],ql,qr);
else
{
return query(node[k].son[0],ql,mid)+query(node[k].son[1],mid+1,qr);
}
}
}*/
long long query(int k,int val)
{
if(node[k].l==node[k].r) return node[k].l;
if(val>node[node[k].son[0]].cnt)return query(node[k].son[1],val-node[node[k].son[0]].cnt);
else query(node[k].son[0],val);
}
int main()
{
std::ios::sync_with_stdio(false);
node[1].l=1; node[1].r=1e9+7;
int n,sth;
cin>>n;
ans=0;
for(int i=1;i<=n;++i)
{
cin>>sth;
modify(1,sth);
}
int m;
cout<<"Please input the number:";
cin>>m;
int v;
for(int i=1;i<=n;++i)
{
cin>>v;
cout<<"The "<<v<<"th max number is: ";
cout<<query(1,v)<<endl;
}
}

总结

其实这个东西可以支持边增加数,边查询第n小,这样总比,加一个数sort一遍要快太多了。然后当你自己已经能够熟练地敲这篇代码的时候,我相信你也很快也可以理解到主席树的精髓!!!

主席树铺垫——总区间第k小的更多相关文章

  1. ZOJ 2112 Dynamic Rankings(树状数组套主席树 可修改区间第k小)题解

    题意:求区间第k小,节点可修改 思路:如果直接用静态第k小去做,显然我更改一个节点后,后面的树都要改,这个复杂度太高.那么我们想到树状数组思路,树状数组是求前缀和,那么我们可以用树状数组套主席树,求出 ...

  2. HDU 2665.Kth number-可持久化线段树(无修改区间第K小)模板 (POJ 2104.K-th Number 、洛谷 P3834 【模板】可持久化线段树 1(主席树)只是输入格式不一样,其他几乎都一样的)

    Kth number Time Limit: 15000/5000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total ...

  3. 主席树(可持久化线段树)静态区间第K小

    传送门主席树 #include <bits/stdc++.h> #define int long long using namespace std; const int maxn=2e5+ ...

  4. SPOJ COT Count on a tree(树上主席树 + LCA 求点第k小)题解

    题意:n个点的树,每个点有权值,问你u~v路径第k小的点的权值是? 思路: 树上主席树就是每个点建一棵权值线段树,具体看JQ博客,LCA用倍增logn求出,具体原理看这里 树上主席树我每个点的存的是点 ...

  5. HDU 2665(主席树,无修改第k小)

    Kth number                                                 Time Limit: 15000/5000 MS (Java/Others)   ...

  6. 可持久化线段树(主席树)——静态区间第k大

    主席树基本操作:静态区间第k大 #include<bits/stdc++.h> using namespace std; typedef long long LL; ,MAXN=2e5+, ...

  7. 主席树 - 查询某区间第 K 大

    You are working for Macrohard company in data structures department. After failing your previous tas ...

  8. 主席树(静态区间第k大)

    前言 如果要求一些数中的第k大值,怎么做? 可以先就这些数离散化,用线段树记录每个数字出现了多少次. ... 那么考虑用类似的方法来求静态区间第k大. 原理 假设现在要有一些数 我们可以对于每个数都建 ...

  9. 主席树入门——询问区间第k大pos2104,询问区间<=k的元素个数hdu4417

    poj2104找了个板子..,但是各种IO还可以进行优化 /* 找区间[l,r]第k大的数 */ #include<iostream> #include<cstring> #i ...

随机推荐

  1. cb01a_c++_数据结构_顺序容器_STL_deque类

    /*cb01a_c++_数据结构_顺序容器_STL_deque类deque是一个动态数组,比vector更加灵活.两者都属于动态数组deque与vector非常类似deque可以在数组开头和末尾插入和 ...

  2. 基于NACOS和JAVA反射机制动态更新JAVA静态常量非@Value注解

    1.前言 项目中都会使用常量类文件, 这些值如果需要变动需要重新提交代码,或者基于@Value注解实现动态刷新, 如果常量太多也是很麻烦; 那么 能不能有更加简便的实现方式呢? 本文讲述的方式是, 一 ...

  3. 002.OpenShift安装与部署

    一 前置条件说明 1.1 安装准备概述 Red Hat OpenShift容器平台是由Red Hat作为RPM包和容器映像两种类型存在.RPM包使用订阅管理器从标准Red Hat存储库(即Yum存储库 ...

  4. 漏洞复现-Office远程代码执行漏洞 (CVE-2017-11882&CVE-2018-0802)

    漏洞原理 这两个漏洞本质都是由Office默认安装的公式编辑器(EQNEDT32.EXE)引发的栈溢出漏洞(不要问什么是栈溢出,咱也解释不了/(ㄒoㄒ)/~~) 影响版本 Office 365 Mic ...

  5. 事务的特性ACID、隔离级别

    1.事务特性ACID 1.1 事务的四大特性 1.原子性(Atomicity) 事务包装的一组sql,要么都执行成功,要么都失败.这些操作是不可分割的. 2.一致性(Consistency) 数据库的 ...

  6. linux环境下安装git(采用github下载git源码编译)

    [目的]:linux环境下 安装配置git成功 [准备条件]linux系统,git包 1.先行下载git包 -- 从github上https://github.com/git/git/releases ...

  7. Qt布局的简单介绍

    1  介绍 参考视频:https://www.bilibili.com/video/BV1XW411x7NU?p=25 布局的好处:布局之后,改变主窗口大小,其余窗口可以自适应. 2  布局分类 垂直 ...

  8. skywalking的插件管理agent管理

    转载自博客:https://my.oschina.net/eacdy/blog/4304312/print Java Agent是插件化.可插拔的.Skywalking的插件分为三种: 引导插件:在a ...

  9. IDEA记坑之移动项目文件之后,import 找不到文件以及出现Cannot access的问题

    今天本想挪动下文件,使项目更加可观,易整理,但是挪动后出现各种问题,import xxx;全部飘红.部分切面还出现Cannot access:试过了重启idea,rebuild....各种方法都行不通 ...

  10. 暑假集训Day2 互不侵犯(状压dp)

    这又是个状压dp (大型自闭现场) 题目大意: 在N*N的棋盘里面放K个国王,使他们互不攻击,共有多少种摆放方案.国王能攻击到它上下左右,以及左上左下右上右下八个方向上附近的各一个格子,共8个格子. ...