• 分裂:如图,按值分裂,u比k大则切黄色的一,此时u接上Y的左子树,然后可见Y的左子树仍然空着,u也递归到其左子树。同理,u比k大则切红色的一,此时u接上X的右子树,然后可见X的右子树仍然空着,u也递归到其右子树。
  • 合并:随机切红色和紫色,合并的是切口上面部分,return合并后的根,,比如,如果切红色,那递归合并X的右子树和Y,并且X的右儿子的指针指向X的右子树和Y合并的结果。

BZOJ3224: Tyvj 1728 普通平衡树

  • 模板题,代码:

     1 #include <bits/stdc++.h>
    2 #define nmax 100010
    3
    4 using namespace std;
    5 int s[nmax][2]={0};
    6 int si[nmax]={0}, v[nmax], r[nmax];
    7 int cnt = 0;
    8
    9 void up(int p){
    10 si[p] = si[ s[p][0] ] + si[ s[p][1] ] + 1;
    11 }
    12
    13 void spilit(int& x, int& y, int k, int u){
    14 if(!u) { x=y=0; return; }
    15 if(v[u] <= k){
    16 x = u;
    17 spilit(s[x][1], y, k, s[x][1]);
    18 }else{
    19 y = u;
    20 spilit(x, s[y][0], k, s[y][0]);
    21 }
    22 up(u);
    23 }
    24
    25 int merge(int x, int y){
    26 if(!x || !y){ return x|y; }
    27 if(r[x] > r[y]) {
    28 s[x][1] = merge(s[x][1], y);
    29 up(x);
    30 return x;
    31 }else{
    32 s[y][0] = merge(x, s[y][0]);
    33 up(y);
    34 return y;
    35 }
    36 }
    37
    38 int kth(int k, int u){
    39 int ans, t;
    40 while(1){
    41 t = si[ s[u][0] ] + 1;
    42 if(k == t) { ans = u; break; }
    43 else if(k < t) u=s[u][0];
    44 else { u=s[u][1]; k-=t; }
    45 }
    46 return v[ans];
    47 }
    48
    49 int newnode(int k){
    50 cnt++;
    51 v[cnt] = k;
    52 si[cnt] = 1;
    53 r[cnt] = rand();
    54 return cnt;
    55 }
    56
    57 int main(){
    58 int n, op, num;
    59 cin >> n;
    60 int x, y, z, root=0;
    61 while(n--){
    62 scanf("%d%d", &op, &num);
    63 switch (op)
    64 {
    65 case 1:
    66 z = newnode(num);
    67 spilit(x, y, num, root);
    68 root = merge( merge(x,z) , y );
    69 break;
    70 case 2:
    71 spilit(x, y, num, root);
    72 spilit(x, z, num-1, x);
    73 z = merge(s[z][0], s[z][1]);
    74 root = merge( merge(x,z), y );
    75 break;
    76 case 3:
    77 spilit(x, y, num-1, root);
    78 printf("%d\n", si[x]+1);
    79 root = merge(x, y);
    80 break;
    81 case 4:
    82 printf("%d\n", kth(num, root) );
    83 break;
    84 case 5:
    85 spilit(x, y, num-1, root);
    86 printf("%d\n", kth(si[x], x) );
    87 root = merge(x, y);
    88 break;
    89 default:
    90 spilit(x, y, num, root);
    91 printf("%d\n", kth(1, y) );
    92 root = merge(x, y);
    93 break;
    94 }
    95 }
    96 return 0;
    97 }

    ( ఠൠఠ )ノ

FHQTreap刷题记录的更多相关文章

  1. PE刷题记录

    PE刷题记录 PE60 / 20%dif 这道题比较坑爹. 所有可以相连的素数可以构成一张图,建出这张图,在其中找它的大小为5的团.注意上界的估算,大概在1W以内.1W内有1229个素数,处理出这些素 ...

  2. leetcode刷题记录--js

    leetcode刷题记录 两数之和 给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标. 你可以假设每种输入只会对应一个答案.但 ...

  3. Leetcode刷题记录(python3)

    Leetcode刷题记录(python3) 顺序刷题 1~5 ---1.两数之和 ---2.两数相加 ---3. 无重复字符的最长子串 ---4.寻找两个有序数组的中位数 ---5.最长回文子串 6- ...

  4. 刷题记录:[HarekazeCTF2019]encode_and_encode

    目录 刷题记录:[HarekazeCTF2019]encode_and_encode 一.知识点 JSON转义字符绕过 php伪协议 刷题记录:[HarekazeCTF2019]encode_and_ ...

  5. 刷题记录:[De1CTF 2019]Giftbox && Comment

    目录 刷题记录:[De1CTF 2019]Giftbox && Comment 一.知识点 1.sql注入 && totp 2.RCE 3.源码泄露 4.敏感文件读取 ...

  6. 刷题记录:[强网杯 2019]Upload

    目录 刷题记录:[强网杯 2019]Upload 一.知识点 1.源码泄露 2.php反序列化 刷题记录:[强网杯 2019]Upload 题目复现链接:https://buuoj.cn/challe ...

  7. 刷题记录:[XNUCA2019Qualifier]EasyPHP

    目录 刷题记录:[XNUCA2019Qualifier]EasyPHP 解法一 1.error_log结合log_errors自定义错误日志 2.include_path设置包含路径 3.php_va ...

  8. 刷题记录:[DDCTF 2019]homebrew event loop

    目录 刷题记录:[DDCTF 2019]homebrew event loop 知识点 1.逻辑漏洞 2.flask session解密 总结 刷题记录:[DDCTF 2019]homebrew ev ...

  9. 刷题记录:[CISCN2019 东北赛区 Day2 Web3]Point System

    目录 刷题记录:[CISCN2019 东北赛区 Day2 Web3]Point System 知识点 1.padding-oracle attack 2.cbc字节翻转攻击 3.FFMpeg文件读取漏 ...

随机推荐

  1. Linux系统下常见的数据盘分区丢失的问题以及对应的处理方法

    在修复数据前,您必须先对分区丢失的数据盘创建快照,在快照创建完成后再尝试修复.如果在修复过程中出现问题,您可以通过快照回滚将数据盘还原到修复之前的状态. 前提条件 在修复数据前,您必须先对分区丢失的数 ...

  2. SSM/SSH框架的MySQL 读写分离实现的一种简单方法

    简介 MySQL已经是使用最为广泛的一种数据库,往往实际使用过程中,为实现高可用及高性能,项目会采用主丛复制的方式实现读写分离.MySQL本身支持复制,通过简单的配置即可实现一主多从的配置,具体实现可 ...

  3. ts的特殊数据类型

    四. Ts数据类型 tuple(元组类型):可以给数组指定位置存指定类型数据 例:let arr:[number, string] = [123, ‘123’]; enum(枚举):将数字转化为标识符 ...

  4. linux入门系列14--ssh服务及主机远程管理

    通过前面十余篇文章的介绍,相信已经初步入门Linux本地管理的基本方法了,后续的文章将介绍Linux中常用的服务部署以及如何为外部提供相应的服务. 系列文章第三篇"linux入门系列3--l ...

  5. Windows AD日志分析平台WatchAD安装教程

    目录 WatchAD介绍 安装环境 WatchAD安装(日志分析端服务) 基础环境配置 安装WatchAD 运行WatchAD WatchAD-web安装(Web监控端服务) 下载WatchAD-We ...

  6. 直接使用汇编编写 .NET Standard 库

    前言 Common Language Runtime(CLR)是一个很强大的运行时,它接收 Common Intermediate Language(CIL) 的输入并最终产生机器代码并执行.CIL ...

  7. js文本复制插件&vue

    /* HTML: * <a href="javascript:;" class="copy" data-clipboard-text="copy ...

  8. [算法] Dijkstra算法(带权有向图 最短路径算法)

    一.带权有向图 二.算法原理 1)由于我们的节点是从1-6,所以我们创建的列表或数组都是n+1的长度,index=0的部分不使用,循环范围为1-6(方便计算). 2)循环之前,我们先初始化dis数组和 ...

  9. SAP MM 采购订单与相关合同的价格差异问题分析

    SAP MM 采购订单与相关合同的价格差异问题分析 笔者所在的项目里,一般生产性物料PO的价格是来自于合同价格的,而合同的价格来自于采购信息记录的价格,业务部门不允许PO里随便改价格的. 但是业务部门 ...

  10. MYSQL使用group by,如何查询出总记录数

    比如有这样一条SQL,根据t.user_id,t.report_date两个字段统计 这样前端页面能展示数据,但往往需要一个总记录数,在有分页的情况下用到 一种解决方法是在外面套一层,然后对其coun ...