poj-2104(区间第K大问题)

 #include <iostream>
#include <algorithm>
#include <cstdio>
#include <cstring>
using namespace std;
struct T {
int ls;
int rs;
int sum;
};
const int N=1e5+;
T tri[*N];
int a[N],sort_a[N];
int rt[N];
int cnt;
int n,m;
void update (int l,int r,int rt1,int &rt2,int pos) {
rt2=++cnt;
tri[rt2]=tri[rt1];
tri[rt2].sum++;// 在此处直接更新,就不用pushup了
if (l==r) return ;
int mid=(l+r)/;
if (pos<=mid) update (l,mid,tri[rt1].ls,tri[rt2].ls,pos);
else update (mid+,r,tri[rt1].rs,tri[rt2].rs,pos);
return ;
}
int query (int l,int r,int rt1,int rt2,int k) {
if (l==r) return sort_a[l];
int mid=(l+r)/;
int sum=tri[tri[rt2].ls].sum-tri[tri[rt1].ls].sum;//我又出错了 sum应该是左子树的节点数 T_T !
if (k<=sum) return query (l,mid,tri[rt1].ls,tri[rt2].ls,k);
else return query (mid+,r,tri[rt1].rs,tri[rt2].rs,k-sum);
}
int main ()
{
scanf ("%d %d",&n,&m);
for (int i=;i<=n;i++) {
scanf ("%d",&a[i]);
sort_a[i]=a[i];
}
sort (sort_a+,sort_a++n);
int num=;
for (int i=;i<=n;i++) {
if (sort_a[i]!=sort_a[i-])
sort_a[++num]=sort_a[i];//离散化
}
rt[]=cnt=;
tri[].sum=tri[].ls=tri[].rs=;
for (int i=;i<=n;i++) {
int pos=lower_bound (sort_a+,sort_a++num,a[i])-sort_a;
update (,num,rt[i-],rt[i],pos);
}
for (int i=;i<=m;i++) {
int x,y,k;
scanf ("%d %d %d",&x,&y,&k);
printf("%d\n",query (,num,rt[x-],rt[y],k));
}
return ;
}

NO.2   HDOJ-4417(主席数的区间求和)

 #include<cstdio>
#include<algorithm>
const int N=1e5+;
using namespace std;
struct node {
int ls;
int rs;
int sum;
};
node tri[*N];
int rt[N];
int a[N],sort_a[N+];
int cnt,n,m,x,y,k;
void updata (int l,int r,int rt1,int& rt2,int pos) {
rt2=(++cnt);
tri[rt2]=tri[rt1];
tri[rt2].sum++;
if (l==r) return ;
int mid=(l+r)/;
if (pos<=mid) updata(l,mid,tri[rt1].ls,tri[rt2].ls,pos);
else updata(mid+,r,tri[rt1].rs,tri[rt2].rs,pos);
return ;
}
int query (int l,int r,int L,int R,int rt1,int rt2) {
if (r<L||l>R) return ;
if (l>=L&&r<=R) return tri[rt2].sum-tri[rt1].sum;
int mid=(l+r)/;
int t1=query(l,mid,L,R,tri[rt1].ls,tri[rt2].ls);
int t2=query(mid+,r,L,R,tri[rt1].rs,tri[rt2].rs);
return t1+t2;
}
int main ()
{
int T;
int tt=;
scanf ("%d",&T);
while (T--) {
printf("Case %d:\n",tt++);
scanf ("%d %d",&n,&m);
for (int i=;i<=n;i++) {
scanf ("%d",&a[i]);
sort_a[i]=a[i];
}
sort(sort_a+,sort_a++n);
int num=;
for (int i=;i<=n;i++) {
if (sort_a[i]!=sort_a[num])
sort_a[++num]=sort_a[i];
}
cnt=;
rt[]=;
tri[].ls=tri[].rs=tri[].sum=;
for (int i=;i<=n;i++) {
int pos=lower_bound(sort_a+,sort_a++num,a[i])-sort_a;
updata(,num,rt[i-],rt[i],pos);
}
for (int i=;i<=m;i++) {
scanf ("%d %d %d",&x,&y,&k);
int t=lower_bound(sort_a+,sort_a++num,k)-sort_a;
if (t>num||sort_a[t]>k) t--;// 这个好 找最后一个小于等于k的数
int ans=query (,num,,t,rt[x],rt[y+]);// 因为题目从0开始计数
printf("%d\n",ans);
}
}
return ;
}

No.3 xdoj-1216(子树第k小)——dfs+主席树

 #include<cstdio>
#include<algorithm>
#include<vector>
using namespace std;
const int N=1e5+;
struct T{
int ls;
int rs;
int sum;
};
vector < vector <int> > g(N);
T tri[N*];
int rt[N],b[N],sort_b[N];
int in[N],out[N];
int val[N];
int cnt,num;
int n,q;
int x,k;
void dfs (int id,int pre) {
num++;
sort_b[num]=b[num]=val[id];
in[id]=num;
for (int i=;i<g[id].size();i++) {
int next=g[id][i];
if (next==pre) continue;
dfs (next,id);
}
out[id]=num;
}
void updata (int l,int r,int pos,int rt1,int& rt2) {
cnt++;
rt2=cnt;
tri[cnt]=tri[rt1];
tri[cnt].sum++;
if (l==r) return ;
int mid=(l+r)/;
if (pos<=mid) updata (l,mid,pos,tri[rt1].ls,tri[rt2].ls);
else updata (mid+,r,pos,tri[rt1].rs,tri[rt2].rs);
return ;
}
int query (int l,int r,int k,int rt1,int rt2) {
if (l==r) return l;
int mid=(l+r)/;
int ans;
int sum=tri[tri[rt2].ls].sum-tri[tri[rt1].ls].sum;
if (k<=sum) ans=query (l,mid,k,tri[rt1].ls,tri[rt2].ls);
else ans=query (mid+,r,k-sum,tri[rt1].rs,tri[rt2].rs);
return ans;
}
int main ()
{
while (scanf ("%d",&n)!=EOF) {
for (int i=;i<=n;i++) g[i].clear();
for (int i=;i<=n;i++)
scanf ("%d",&val[i]);
int u,v;
for (int i=;i<=n-;i++) {
scanf ("%d %d",&u,&v);
g[u].push_back(v);
g[v].push_back(u);
}
num=;
dfs (,-);// 按理说有根树 直接dfs(1)就可以了可是这样答案是不对的 是我理解错了还是数据有问题呢
sort(sort_b+,sort_b++n);
int nn=;
for (int i=;i<=n;i++)
if (sort_b[i]!=sort_b[nn])
sort_b[++nn]=sort_b[i];
rt[]=;
tri[].rs=tri[].ls=tri[].sum=;
cnt=;
for (int i=;i<=n;i++) {
int pos=lower_bound(sort_b+,sort_b++nn,b[i])-sort_b;
updata(,nn,pos,rt[i-],rt[i]);
}
scanf ("%d",&q);
for (int i=;i<=q;i++) {
scanf ("%d %d",&x,&k);
int ans=query (,nn,k,rt[in[x]-],rt[out[x]]);
printf ("%d\n",sort_b[ans]);
}
}
return ;
}

线段树专题2-(加强版线段树-可持续化线段树)主席树 orz! ------用于解决区间第k大的问题----xdoj-1216的更多相关文章

  1. POJ 2104 HDU 2665 主席树 解决区间第K大

    两道题都是区间第K大询问,数据规模基本相同. 解决这种问题, 可以采用平方划分(块状表)复杂度也可以接受,但是实际表现比主席树差得多. 这里大致讲一下我对主席树的理解. 首先,如果对于某个区间[L,R ...

  2. 可持久化线段树(主席树)(图文并茂详解)【poj2104】【区间第k大】

    [pixiv] https://www.pixiv.net/member_illust.php?mode=medium&illust_id=63740442 向大(hei)佬(e)实力学(di ...

  3. Permutation UVA - 11525(值域树状数组,树状数组区间第k大(离线),log方,log)(值域线段树第k大)

    Permutation UVA - 11525 看康托展开 题目给出的式子(n=s[1]*(k-1)!+s[2]*(k-2)!+...+s[k]*0!)非常像逆康托展开(将n个数的所有排列按字典序排序 ...

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

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

  5. 【BZOJ3551】Peaks加强版(Kruskal重构树,主席树)

    [BZOJ3551]Peaks加强版(Kruskal重构树,主席树) 题面 BZOJ Description 在Bytemountains有N座山峰,每座山峰有他的高度h_i.有些山峰之间有双向道路相 ...

  6. 主席树入门(区间第k大)

    主席树入门 时隔5个月,我又来填主席树的坑了,现在才发现学算法真的要懂了之后,再自己调试,慢慢写出来,如果不懂,就只会按照代码敲,是不会有任何提升的,都不如不照着敲. 所以搞算法一定要弄清原理,和代码 ...

  7. 【ZOJ2112】【整体二分+树状数组】带修改区间第k大

    The Company Dynamic Rankings has developed a new kind of computer that is no longer satisfied with t ...

  8. POJ2104-- K-th Number(主席树静态区间第k大)

    [转载]一篇还算可以的文章,关于可持久化线段树http://finaltheory.info/?p=249 无修改的区间第K大 我们先考虑简化的问题:我们要询问整个区间内的第K大.这样我们对值域建线段 ...

  9. hdu 5919--Sequence II(主席树--求区间不同数个数+区间第k大)

    题目链接 Problem Description Mr. Frog has an integer sequence of length n, which can be denoted as a1,a2 ...

随机推荐

  1. Jackson 工具类使用及配置指南

    目录 前言 Jackson使用工具类 Jackson配置属性 Jackson解析JSON数据 Jackson序列化Java对象 前言 Json数据格式这两年发展的很快,其声称相对XML格式有很对好处: ...

  2. vue cli搭建的vue项目 不小心开了eslint 一直报黄色的警告

    报错必须处理,警告也忍不了,发现在bulid -webpack.base.config.js 里找到 const createLintingRule = () => ({ /*test: /\. ...

  3. 转 Visual C++6.0 与matlab联合编程(2)----Visual C++6.0 环境下编译和调试MEX文件

    我的最初想法是利用matlab的mex命令调用C++程序生成动态链接库的,但是测试程序(文中另附)通过了,自己的实际应用程序却没有过.还是把方法贴在这儿,以便自己以后进行整理. http://shij ...

  4. RegDataToDataType

    function RegDataToDataType(Value: TRegDataType): Integer; begin case Value of rdString: Result := RE ...

  5. Mac下安装ipython与jupyter

    IPython从Python发展而来,更倾向于科学计算.互联网数据分析更喜欢用. 首先切换root用户: sudo su - pip3自动安装ipython yuchaodeMacBook-Pro:~ ...

  6. cv::ACCESS_MASK指定不明确的错误

    今天想实现在opencv下使用模拟按键,结果出现cv::ACCESS_MASK指定不明确的错误,查找得到如下原因: 在winnt.h里面有一个cv的命名空间,同样定义了一个ACCESS_MASK,跟o ...

  7. :迭代器模式1:Iterator

    //今天一口气把这一章前半部分的iterator例子的所有代码写完,涉及到了不少指针的内容,竟然一次性编译通过.... //Iterator与Menu之间应该不是has a的关系,先这样着吧. #if ...

  8. 接口测试-webservice接口---soapui

    1.添加项目 2.填入wsdl地址 3.编辑参数,运行接口

  9. SharePoint online Multilingual support - Settings

    博客地址:http://blog.csdn.net/FoxDave This post will talk about how to enable sharepoint online site mul ...

  10. el-container 实践上的布局问题

    当自己利用element-ui上面的例子来实现整体布局的时候, 就是自己分开成单独的vue组件时,发现布局是不对的,效果是这样的: 代码是这样的,代码一模一样,只是拆开了各个组件,如下图: 后来发现是 ...