原来主席树就是可持久化线段树啊,刚知道,,,

作为一道裸题,还是必A的,然而一开始偷懒不写离散化跪了N多遍,后来在缪大的帮助下发现了这个问题,遂A之

——又是这种破问题,实在不想说自己了

把n个数看成n次修改,对于每一次都建线段树,于是就能得到N棵线段树

然后时间空间全都爆炸,我们得到了完美的程序

但是每次因为只修一个叶子,所以只有一条根到叶的节点被修改,只要把这一部分备份一份就好了

最后返回新的根,用于保存

最后求的时候只要把两端点(左端点-1)的线段树上的点权值一减就搞定了

代码难看的要死,离散化是后来加的,看得出加的很生硬

#include <cstdio>
#include <algorithm>
#define INF 2000000000
#define max n
#define min 1
using namespace std;
struct node
{
    int val,ls,rs;
} t[];
;
struct num
{
    int val,ran,rea;
} a[];
bool operator<(num a,num b)
{
    return a.val<b.val;
}
bool com(num a,num b)
{
    return a.ran<b.ran;
}
],dui[];
int add(int now,int l,int r,int x)
{
    ;
    t[ne]=t[now];
    t[ne].val++;
    if(l<r)
    if(x<=mid)
        t[ne].ls=add(t[now].ls,l,mid,x);
    else
        t[ne].rs=add(t[now].rs,mid+,r,x);
    return ne;
}
int main()
{
    int n,m;
    scanf("%d%d",&n,&m);
    ;i<=n;i++)
    {
        scanf("%d",&a[i].val);
        a[i].ran=i;
    }
    sort(a+,a+n+);
    ;i<=n;i++)
    {
        a[i].rea=i;
        dui[a[i].rea]=a[i].val;
    }
    sort(a+,a+n+,com);
    ;i<=n;i++)
        root[i]=add(root[i-],min,max,a[i].rea);
    ;i<=m;i++)
    {
        int x,y,z,l,r,mid;
        scanf("%d%d%d",&x,&y,&z);
        ],y=root[y],l=min,r=max,mid=(l+r)/;l<r;mid=(l+r)/)
        if(t[t[y].ls].val-t[t[x].ls].val<z)
        {
            z-=t[t[y].ls].val-t[t[x].ls].val;
            x=t[x].rs;y=t[y].rs;
            l=mid+;
        }
        else
        {
            x=t[x].ls;y=t[y].ls;
            r=mid;
        }
        printf("%d\n",dui[l]);
    }
    ;
}

poj2104 K-th Number区间第k小值 主席树的更多相关文章

  1. Dynamic Rankings || 动态/静态区间第k小(主席树)

    JYF大佬说,一星期要写很多篇博客才会有人看 但是我做题没有那么快啊QwQ Part1 写在前面 区间第K小问题一直是主席树经典题=w=今天的重点是动态区间第K小问题.静态问题要求查询一个区间内的第k ...

  2. HDU 2665.Kth number 区间第K小

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

  3. POJ 2014.K-th Number 区间第k小 (归并树)

    K-th Number Time Limit: 20000MS   Memory Limit: 65536K Total Submissions: 57543   Accepted: 19893 Ca ...

  4. bzoj 3065: 带插入区间K小值 替罪羊树 &amp;&amp; AC300

    3065: 带插入区间K小值 Time Limit: 60 Sec  Memory Limit: 512 MBSubmit: 1062  Solved: 253[Submit][Status] Des ...

  5. [luogu3834]静态区间第k小【主席树】

    传送门:https://www.luogu.org/problemnew/show/P3834 题目描述 如题,给定N个整数构成的序列,将对于指定的闭区间查询其区间内的第K小值. 分析 很多人都说是用 ...

  6. 【题解】BZOJ 3065: 带插入区间K小值——替罪羊树套线段树

    题目传送门 题解 orz vfk的题解 3065: 带插入区间K小值 系列题解 一 二 三 四 惨 一开始用了一种空间常数很大的方法,每次重构的时候merge两颗线段树,然后无限RE(其实是MLE). ...

  7. BZOJ 3110([Zjoi2013]K大数查询-区间第k大[段修改,在线]-树状数组套函数式线段树)

    3110: [Zjoi2013]K大数查询 Time Limit: 20 Sec   Memory Limit: 512 MB Submit: 418   Solved: 235 [ Submit][ ...

  8. spoj COT - Count on a tree (树上第K小 LCA+主席树)

    链接: https://www.spoj.com/problems/COT/en/ 思路: 首先看到求两点之前的第k小很容易想到用主席树去写,但是主席树处理的是线性结构,而这道题要求的是树形结构,我们 ...

  9. 少年,想学带修改主席树吗 | BZOJ1901 带修改区间第k小

    少年,想学带修改主席树吗 | BZOJ1901 带修改区间第k小 有一道题(BZOJ 1901)是这样的:n个数,m个询问,询问有两种:修改某个数/询问区间第k小. 不带修改的区间第k小用主席树很好写 ...

随机推荐

  1. h5页面 禁止缩放

    <head><meta name="viewport" content="width=device-width,minimum-scale=1.0,ma ...

  2. spi can&#39;t create GMem lock

    管理员身份启动cmd,输入下方命令 netsh winsock reset Successfully之后重启电脑就解决了

  3. Python学习【第二篇】Python入门

    Python入门 Hello World程序 在linux下创建一个叫hello.py,并输入 print("Hello World!") 然后执行命令:python hello. ...

  4. listview实现点击条目上的箭头展开隐藏菜单。

    效果如下图,当点击listview中的小三角时,显示出下面布局,再点隐藏, 点击其他条目的三角时,上一个展开的条目隐藏的同时展开当前条目. 思路是在item布局中放入展开菜单的布局,并设置状态为隐藏, ...

  5. 5月23日 JavaScript

    一.JavaScript简介 1.JavaScript是什么: 它是个脚本语言,需要有宿主文件,它的宿主文件是HTML文件. 2.它的用法: 在HTML中位置有三块: (1)head里面 (2)bod ...

  6. 使用apt-get autoremove造成的系统无法开机

    由于误操作(apt-get autoremove xxx)删除了一些lib文件貌似,之后,系统直接重启,然后就无法进入系统,后使用引导盘对系统进行修复,思路如下: 1.挂载已经有的分区,挂载为可读可写 ...

  7. 转载:linux capability深入分析

    转至http://www.cnblogs.com/iamfy/archive/2012/09/20/2694977.html 一)概述:  1)从2.1版开始,Linux内核有了能力(capabili ...

  8. Critical Log Review Checklist for Security Incidents

    Critical Log Review Checklist for Security Incidents This cheat sheet presents a checklist for revie ...

  9. asp.net mvc3 数据验证(四)—Remote验证的一个注意事项

    原文:asp.net mvc3 数据验证(四)-Remote验证的一个注意事项         前几篇把asp.net mvc3 中基于Model的主要数据验证的方法都已经讲完了,本节纯粹只是讲一个我 ...

  10. 严重: Could not synchronize database state with session org.hibernate.exception.DataException: Could not execute JDBC batch update

    p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 12.0px Monaco; color: #ff2600 } p.p2 { margin: 0.0px 0 ...