洛谷P3835 【模板】可持久化平衡樹

来源:http://www.cnblogs.com/zwfymqz/archive/2017/12/09/8012696.html
-Advertisement-
Play Games

題目背景 本題為題目 普通平衡樹 的可持久化加強版。 數據已經經過強化 題目描述 您需要寫一種數據結構(可參考題目標題),來維護一些數,其中需要提供以下操作(對於各個以往的歷史版本): 插入x數 刪除x數(若有多個相同的數,因只刪除一個,如果沒有請忽略該操作) 查詢x數的排名(排名定義為比當前數小的 ...


題目背景

本題為題目 普通平衡樹 的可持久化加強版。

數據已經經過強化

題目描述

您需要寫一種數據結構(可參考題目標題),來維護一些數,其中需要提供以下操作(對於各個以往的歷史版本):

  1. 插入x數

  2. 刪除x數(若有多個相同的數,因只刪除一個,如果沒有請忽略該操作)

  3. 查詢x數的排名(排名定義為比當前數小的數的個數+1。若有多個相同的數,因輸出最小的排名)

  4. 查詢排名為x的數

  5. 求x的前驅(前驅定義為小於x,且最大的數,如不存在輸出-2147483647)

  6. 求x的後繼(後繼定義為大於x,且最小的數,如不存在輸出2147483647)

和原本平衡樹不同的一點是,每一次的任何操作都是基於某一個歷史版本,同時生成一個新的版本。(操作3, 4, 5, 6即保持原版本無變化)

每個版本的編號即為操作的序號(版本0即為初始狀態,空樹)

輸入輸出格式

輸入格式:

 

第一行包含一個正整數N,表示操作的總數。

接下來每行包含三個正整數,第 ii 行記為 v_i, opt_i, x_ivi,opti,xi

v_ivi表示基於的過去版本號( 0 \leq v_i < i0vi<i ),opt_iopti 表示操作的序號( 1 \leq opt \leq 61opt6 ), x_ixi 表示參與操作的數值

 

輸出格式:

 

每行包含一個正整數,依次為各個3,4,5,6操作所對應的答案

 

輸入輸出樣例

輸入樣例#1: 複製
10
0 1 9
1 1 3
1 1 10
2 4 2
3 3 9
3 1 2
6 4 1
6 2 9
8 6 3
4 5 8
輸出樣例#1: 複製
9
1
2
10
3

說明

數據範圍:

對於10%的數據滿足: 1 \leq n \leq 101n10

對於30%的數據滿足: 1 \leq n \leq 2\cdot {10}^21n2102

對於50%的數據滿足: 1 \leq n \leq 3\cdot {10}^31n3103

對於80%的數據滿足: 1 \leq n \leq {10}^51n105

對於90%的數據滿足: 1 \leq n \leq 2\cdot {10}^51n2105

對於100%的數據滿足: 1 \leq n \leq 5\cdot {10}^51n5105 , -{10}^9 \leq x_i \leq {10}^9109xi109

經實測,正常常數的可持久化平衡樹均可通過,請各位放心

樣例說明:

共10次操作,11個版本,各版本的狀況依次是:

  1. [][]

  2. [9][9]

  3. [3, 9][3,9]

  4. [9, 10][9,10]

  5. [3, 9][3,9]

  6. [9, 10][9,10]

  7. [2, 9, 10][2,9,10]

  8. [2, 9, 10][2,9,10]

  9. [2, 10][2,10]

  10. [2, 10][2,10]

  11. [3, 9][3,9]

 

也是沒誰了

數據壓根就沒有5.6的21***的情況

而且不知道為啥我的樣例沒過就A了。。

 

#include<bits/stdc++.h>
using namespace std;
#define ls tree[k].ch[0]
#define rs tree[k].ch[1]
const int MAXN=1e6+10,INF=1e7;
inline char nc()
{
    static char buf[MAXN],*p1=buf,*p2=buf;
    return p1==p2&&(p2=(p1=buf)+fread(buf,1,MAXN,stdin),p1==p2)?EOF:*p1++;
}
inline int read()
{
    char c=nc();int x=0,f=1;
    while(c<'0'||c>'9'){if(c=='-')f=-1;c=nc();}
    while(c>='0'&&c<='9'){x=x*10+c-'0';c=nc();}
    return x*f;
}
struct node
{
    int pri,v,ch[2],siz;
}tree[MAXN];
int x,y,z,tot=0,root[MAXN];
int new_node(int val)
{
    tree[++tot].pri=rand()*rand(),tree[tot].v=val,tree[tot].siz=1;
    return tot;
}
void update(int k){   tree[k].siz=tree[ls].siz+tree[rs].siz+1; }
void split(int now,int k,int &x,int &y)
{
    if(!now)  {x=y=0;return ;}
    if(tree[now].v<=k)  x=now,split(tree[now].ch[1],k,tree[now].ch[1],y);
    else y=now,split(tree[now].ch[0],k,x,tree[now].ch[0]);
    update(now);
}
int merge(int x,int y)
{
    if(!x||!y)  return x+y;
    if(tree[x].pri<tree[y].pri) {tree[x].ch[1]=merge(tree[x].ch[1],y),update(x);return x;}
    else {tree[y].ch[0]=merge(x,tree[y].ch[0]),update(y);return y;}
}
int kth(int k,int x)// 查詢排名 
{
    if(x<=tree[ls].siz)           return kth(ls,x);
    else if(x==tree[ls].siz+1)    return k;
    else return kth(rs,x-tree[ls].siz-1);
}
int main()
{ 
    #ifdef WIN32
    freopen("a.in","r",stdin);
    #else 
    #endif
    srand((unsigned)time(NULL));
    int n=read();
    for(int i=1;i<=n;i++)
    {
        int pre=read(),how=read(),a=read();
        root[i]=root[pre];     
        if(how==1)      split(root[i],a,x,y),root[i]=merge(merge(x,new_node(a)),y);
        else if(how==2) split(root[i],a,x,z),split(x,a-1,x,y),y=merge(tree[y].ch[0],tree[y].ch[1]),root[i]=merge(merge(x,y),z);
        else if(how==3) split(root[i],a-1,x,y),printf("%d\n",tree[x].siz+1),root[i]=merge(x,y);
        else if(how==4) printf("%d\n",tree[kth(root[i],a)].v);
        else if(how==5)    split(root[i],a-1,x,y),printf("%d\n",tree[kth(x,tree[x].siz)].v),root[i]=merge(x,y);
        else if(how==6) split(root[i],a,x,y),printf("%d\n",tree[kth(y,1)].v),root[i]=merge(x,y);
    }
    return 0;
}

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 其實學java一般要多久?因人而異,有些人資質好,頭腦聰明幾個月就能學會,有些人天生愚鈍,理解能力差,不過勤能補拙,只是時間相對長點 要堅持住。不過java相對於C,C++java而言,java無疑簡單了很多,不需要指針,不需要銷毀對象,使得對java初學者來講更容易入門,挫折感也少。 很多人自學j ...
  • 使用RSA公鑰解密,用openssl命令就是openssl rsautl -verify -in cipher_text -inkey public.pem -pubin -out clear_text,但其python網上還真沒有找到有博文去寫,只有hash的rsa解簽名。 這裡使用rsa庫,如果 ...
  • 一、python特性概要 1. python是解釋性腳本語言。 2. python特性總結 2.1 位元組碼 2.2 動態語義 在賦值是確定數據類型 2.3 縮進(4個空格) 3. python定義編碼類型 # -*- coding: utf-8 -*- 或 # -*- coding= utf-8 - ...
  • 題目描述 請你找出M個和為N的正整數,他們的乘積要儘可能的大。 輸出字典序最小的一種方案。 輸入輸出格式 輸入格式: 一行,兩個正整數N,M 輸出格式: M個和為N的,乘積儘可能的大的正整數。 輸入輸出樣例 輸入樣例#1: 複製 6 3 輸出樣例#1: 複製 2 2 2 輸入樣例#1: 複製 6 3 ...
  • 系統環境:win10 軟體:sublime Text 3 安裝插件: markdown editing.markdownlivepreview 修改prference-markdownlivepreview,複製左邊到右邊第一項設置為true。 下麵記錄了一些基本使用語法: #這是標題##這個是二級 ...
  • 前言 在javaEE中,最老生常談的莫過於SSH框架了,雖然現在類似struts的框架已經有很多了,但是我們還是不能夠忽視這個框架蘊含的一些知識。所以接下來的博文,筆者會根據struts的相關知識進行一些相關的講解。 一、struts框架的概述 1.1什麼是struts2? 以上是百度百科的對於st ...
  • 題目描述 Farmer John suffered a terrible loss when giant Australian cockroaches ate the entirety of his hay inventory, leaving him with nothing to feed th ...
  • 今天我們聊聊 Java 線程的中斷機制。 線程中斷機制提供了一種方法,用於將線程從阻塞等待中喚醒,並作出相應的“受控中斷”處理。 這段代碼使用了 Java 提供的 wait/notify 機制,線程執行 lock.wait() 會阻塞,有三種情況使線程恢復運行。 超時 1000ms 結束,正常執行下 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...