日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

PASTE Splay

發(fā)布時(shí)間:2023/12/13 编程问答 26 豆豆
生活随笔 收集整理的這篇文章主要介紹了 PASTE Splay 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

題目描述

  我們用文本處理器來(lái)處理一個(gè)特殊的文本文件,該文本文件共有N行文本,每一行文本僅包含一個(gè)自然數(shù),第一行為1、第二行為2,以此類推至N行為自然數(shù)N。
  假設(shè)對(duì)該文本文件執(zhí)行一次“剪切和粘貼”操作含義如下:首先選定連續(xù)的若干行文本,“剪切”操作將選定的文本從文件中剪下,而“粘貼”操作將剪切下來(lái)的文本插入到文件中的其他地方。
  編寫(xiě)一個(gè)程序求出在進(jìn)行了連續(xù)若干次“剪切和粘貼”操作后,文本文件中前十行的內(nèi)容。

題目大意

將區(qū)間內(nèi)的一段數(shù)字移動(dòng)到另一個(gè)地方,求操作后的區(qū)間前10個(gè)數(shù)字。

數(shù)據(jù)范圍

10<=n<=100000 1<=k<=1000

樣例輸入

13 3
6 12 1
2 9 0
10 13 8

樣例輸出

6
7
8
9
10
11
12
2
3
4

解題思路

  Splay 維護(hù)區(qū)間,如果要剪切,就先把區(qū)間旋轉(zhuǎn)出來(lái),再斷邊,在把要插入的地方旋轉(zhuǎn)出來(lái),連邊。(雖然我并不知道這道題目的標(biāo)解是什么。。)


Update:最后發(fā)現(xiàn)O(nk)的模擬可以直接過(guò)QAQ

代碼

#include <bits/stdc++.h> #define Maxn 100005 using namespace std; inline int Getint(){int x=0,f=1;char ch=getchar();while('0'>ch||ch>'9'){if(ch=='-')f=-1;ch=getchar();}while('0'<=ch&&ch<='9'){x=x*10+ch-'0';ch=getchar();}return x*f;} int n,q; struct splay{int f[Maxn],son[Maxn][2],size[Maxn],vl[Maxn],root;void PushUp(int v){if(v)size[v]=size[son[v][0]]+size[son[v][1]]+1;}void Rotate(int x){int fa=f[x],gr=f[fa],s=son[fa][1]==x,sn=son[x][!s];son[f[x]=gr][son[gr][1]==fa]=x;son[f[fa]=x][!s]=fa;son[f[sn]=fa][s]=sn;PushUp(sn);PushUp(fa);PushUp(x);}void Splay(int x,int goal){if(x==goal)return;while(f[x]!=goal){if(f[f[x]]!=goal&&(son[f[f[x]]][1]==f[x])==(son[f[x]][1]==x))Rotate(f[x]);Rotate(x);}if(!goal)root=x;}int Select(int pos){int p=root;while(size[son[p][0]]+1!=pos){if(pos<=size[son[p][0]])p=son[p][0];else pos-=size[son[p][0]]+1,p=son[p][1];}return p;}void Insert(int pos,int k){int u=Select(pos+1),v=Select(pos+2);Splay(u,0);Splay(v,u);son[v][0]=k;f[son[v][0]]=v;PushUp(v);PushUp(u);}int Delete(int L,int r){int u=Select(L),v=Select(r+2);Splay(u,0);Splay(v,u);f[son[v][0]]=0;PushUp(v);PushUp(u);int t=son[v][0];son[v][0]=0;return t;}void Build(int L,int r,int fa){if(L>r)return;int mid=(L+r)/2;if(L!=r)Build(L,mid-1,mid),Build(mid+1,r,mid);vl[mid]=(mid-1<=n?mid-1:0);PushUp(mid);f[mid]=fa;son[fa][mid>=fa]=mid;}void Init(){Build(1,n+2,0);root=n+3>>1;} }Solver; int main(){n=Getint(),q=Getint();Solver.Init();while(q--){int L=Getint(),r=Getint(),k=Getint();Solver.Insert(k,Solver.Delete(L,r));}for(int i=1;i<=10;i++)cout<<Solver.vl[Solver.Select(i+1)]<<"\n";return 0; }

轉(zhuǎn)載于:https://www.cnblogs.com/Cedric341561/p/6811006.html

創(chuàng)作挑戰(zhàn)賽新人創(chuàng)作獎(jiǎng)勵(lì)來(lái)咯,堅(jiān)持創(chuàng)作打卡瓜分現(xiàn)金大獎(jiǎng)

總結(jié)

以上是生活随笔為你收集整理的PASTE Splay的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。