[51nod1297]管理二叉樹

一個初始為空的二叉搜索樹T,以及1到N的一個排列P: {a1, a2, ..., aN}。我們向這個二叉搜索樹T添加這些數,從a1開始, 接下來是 a2, ..., 以aN結束。在每一個添加操作后,輸出T上每對節點之間的距離之和。
例如:4 7 3 1 8 2 6 5。最終的二叉樹為:
4
/ ? \
3 ? ? ?7 ??
/ ? ? ?/ ? \
1 ? ? ?6 ? ? 8
\ ? ?/
2 ?5
節點兩兩之間的距離和 =?6+5+5+4+3+2+1+5+4+4+3+2+1+4+3+3+2+1+3+2+2+1+2+1+1+2+1+3 = 76

 Input
  第1行:1個數N。(1 <= N <= 100000)
  第2 - N + 1行:每行1個數,對應排列的元素。(1 <= ai <= N)
 Output
  輸出共N行,每行1個數,對應添加當前元素后,每對節點之間的距離之和。

?

?

  先把樹求出來。。具體的話就是每次添加元素之后,找到這個數的前驅后繼,哪個有空位這個元素就在哪。隨便寫個什么數據結構。

  求節點的距離和的話。。我寫了點分治,每次查找完往里面加點...查找啊去重啊什么的都是一樣的套路...

  1 #include<cstdio>
  2 #include<iostream>
  3 #include<cstring>
  4 #include<algorithm>
  5 #include<queue>
  6 #include<cmath>
  7 #include<cstdlib>
  8 #include<bitset>
  9 //#include<ctime>
 10 #define ll long long
 11 #define ull unsigned long long
 12 #define ui unsigned int
 13 #define d double
 14 //#define ld long double
 15 using namespace std;
 16 const int maxn=100233,mxnode=maxn;
 17 struct zs{int too,pre;}e[maxn<<1];int tot,last[maxn];
 18 int lc[mxnode],rc[mxnode],v[mxnode],rnd[mxnode],tt;int V,PRE,AFT,rt;bool u[maxn][2];
 19 int sz[maxn],mx[maxn],RT,POI,dis[maxn],st[maxn],top,mxdep[maxn];bool del[maxn];
 20 int bel[maxn][20],belson[maxn<<1][20],dist[maxn][20],_sz[maxn],_sonsz[maxn<<1];int ID;
 21 ll _sum[maxn],_sonsum[maxn<<1];
 22 int a[maxn];
 23 int i,j,k,n,m;
 24 
 25 int ra,fh;char rx;
 26 inline int read(){
 27     rx=getchar(),ra=0,fh=1;
 28     while((rx<'0'||rx>'9')&&rx!='-')rx=getchar();
 29     if(rx=='-')fh=-1,rx=getchar();
 30     while(rx>='0'&&rx<='9')ra=ra*10+rx-48,rx=getchar();return ra*fh;
 31 }
 32 inline void maxs(int &a,int b){if(b>a)a=b;}
 33 inline void lturn(int &x){int R=rc[x];rc[x]=lc[R],lc[R]=x,x=R;}
 34 inline void rturn(int &x){int L=lc[x];lc[x]=rc[L],rc[L]=x,x=L;}
 35 inline void insert(int &x){
 36     if(!x){x=++tt,v[x]=V,rnd[x]=rand();return;}
 37     if(V<v[x]){
 38         insert(lc[x]);
 39         if(rnd[lc[x]]<rnd[x])rturn(x);
 40     }else{
 41         insert(rc[x]);
 42         if(rnd[rc[x]]<rnd[x])lturn(x);
 43     }
 44 }
 45 void getpre(int x){
 46     if(!x)return;
 47     if(v[x]<V)PRE=v[x],getpre(rc[x]);else getpre(lc[x]);
 48 }
 49 void getaft(int x){
 50     if(!x)return;
 51     if(v[x]>V)AFT=v[x],getaft(lc[x]);else getaft(rc[x]);
 52 }
 53 inline void ins(int a,int b){
 54     e[++tot].too=b,e[tot].pre=last[a],last[a]=tot;
 55     e[++tot].too=a,e[tot].pre=last[b],last[b]=tot;
 56 }
 57 
 58 
 59 void getrt(int x,int fa){
 60     sz[x]=1,mx[x]=0;
 61     for(int i=last[x];i;i=e[i].pre)if(e[i].too!=fa&&!del[e[i].too])
 62         getrt(e[i].too,x),maxs(mx[x],sz[e[i].too]),sz[x]+=sz[e[i].too];
 63     maxs(mx[x],POI-sz[x]);
 64     if(mx[x]<mx[RT])RT=x;
 65 }
 66 void getpoi(int x,int fa){
 67     dis[x]=dis[fa]+1,st[++top]=x,sz[x]=1;
 68     for(int i=last[x];i;i=e[i].pre)if(e[i].too!=fa&&!del[e[i].too])
 69         getpoi(e[i].too,x),sz[x]+=sz[e[i].too];
 70 }
 71 void work(int x,int dep){
 72     int i,p;
 73     RT=0,getrt(x,0),x=RT,mxdep[x]=dep,bel[x][dep]=x,dist[x][dep]=dis[x]=0;
 74     for(i=last[x];i;i=e[i].pre)if(!del[e[i].too]){
 75         getpoi(e[i].too,x);ID++;
 76         while(top)p=st[top--],bel[p][dep]=x,belson[p][dep]=ID,dist[p][dep]=dis[p];
 77     }
 78     del[x]=1,sz[x]=-233;
 79     for(i=last[x];i;i=e[i].pre)if(!del[e[i].too])
 80         POI=sz[e[i].too],work(e[i].too,dep+1);
 81 }
 82 
 83 int main(){
 84     n=read();
 85     for(i=1;i<=n;i++){
 86         a[i]=read();
 87         if(i>1){
 88             PRE=AFT=0,V=a[i],getpre(rt),getaft(rt),
 89             insert(rt);
 90             if(!PRE||!AFT)ins(PRE|AFT,a[i]),u[PRE|AFT][PRE>0]=1;
 91             else if(!u[PRE][1])u[PRE][1]=1,ins(PRE,a[i]);
 92             else u[AFT][0]=1,ins(AFT,a[i]);
 93         }else V=a[i],insert(rt);
 94     }
 95 //    for(i=1;i<=n;i++)for(j=last[i];j;j=e[j].pre)printf("%d-->%d\n",i,e[j].too);
 96     
 97     mx[0]=1<<30,POI=n,work(a[1],1);ll ans=0;int fa,son,dis;
 98     for(i=1;i<=n;i++){
 99         k=a[i];
100         
101         ans+=_sum[k],_sz[k]++;
102         for(j=mxdep[k]-1;j;j--)
103             fa=bel[k][j],son=belson[k][j],dis=dist[k][j],
104             ans+=1ll*dis*(_sz[fa]-_sonsz[son])+_sum[fa]-_sonsum[son],
105             _sz[fa]++,_sonsz[son]++,_sum[fa]+=dis,_sonsum[son]+=dis;
106         
107         printf("%lld\n",ans);
108     }
109 }
View Code

?

轉載于:https://www.cnblogs.com/czllgzmzl/p/5956304.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/372214.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/372214.shtml
英文地址,請注明出處:http://en.pswp.cn/news/372214.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Java Swing中的聊天氣泡

本文將向您解釋“如何在Java swing應用程序中繪制聊天氣泡&#xff1f;” 聊天氣泡與呼出氣泡或思想氣泡相同。 今天&#xff0c;大多數聊天應用程序都以這種格式顯示轉換&#xff0c;因此本文將幫助您在用Java swing創建的桌面應用程序中進行相同的操作。 以下課程用于繪制第一…

java內存模型按照線程隔離性_深入理解Java多線程與并發框(第③篇)——Java內存模型與原子性、可見性、有序性...

一、Java內存模型Java Memory Modle&#xff0c;簡稱 JMM&#xff0c;中文名稱 Java內存模型&#xff0c;它是一個抽象的概念&#xff0c;用來描述或者規范訪問內存變量的方式。因為各中計算機的操作系統和硬件不同&#xff0c;方式機制也可能不同&#xff0c;Java內存模型用于…

PHP通過PDO連接Microsoft Access數據庫

1連接到access數據庫 $db new PDO("odbc:Driver{Microsoft Access Driver (*.mdb, *.accdb)}; dbq" .realpath("yourfilepath\# ddsbbn3A02.Mdb")) or die("Connect Error"); realpath函數用來規范化絕對路徑 2修改數據庫中BM_sitelink表中字段…

ZK實際應用:樣式和布局

在之前的ZK in Action帖子中&#xff0c;我們使用ZK MVVM實現了CRUD功能 。 我們還快速瀏覽了一些樣式代碼&#xff0c;可能需要更多的解釋。 在本文中&#xff0c;我們將討論如何在ZK小部件上附加新CSS樣式規則&#xff0c;以及如何覆蓋現有樣式。 我們還將介紹ZK中UI布局的一…

java面向對象的三大特征是6_Java面向對象的三大特征

面向對象的本質&#xff1a;以類的方式組織代碼&#xff0c;以對象的方式組織數據。面向對象三大特性&#xff1a;封裝 繼承 多態封裝&#xff1a;概念&#xff1a;隱藏對象內部的復雜性&#xff0c;只對外公開簡單的接口。便于外界調用&#xff0c;從而提高系統的可擴展性&…

Tornado(一)

Tornado 特點 Tornado是一個用Python寫的相對簡單的、不設障礙的Web服務器架構&#xff0c;用以處理上萬的同時的連接口&#xff0c;讓實時的Web服務通暢起來。雖然跟現在的一些用Python寫的Web架構相似&#xff0c;比如Django&#xff0c;但Tornado更注重速度&#xff0c;能夠…

Android下Opengl ES實現單屏幕雙眼顯示

http://blog.csdn.net/u011371324/article/details/68946779 默認情況下&#xff0c;Opengl ES使用系統提供的幀緩沖區作為繪圖表面&#xff0c;一般情況下&#xff0c;如果只在屏幕的表面繪圖的話&#xff0c;系統提供的默認幀緩沖區很高效&#xff0c;但是很多應用程序需要渲…

Oracle Service Bus –線程阻塞案例研究

本案例研究描述了在AIX 6.1和IBM Java VM 1.6上運行的Oracle Service Bus 11g遇到的線程阻塞問題的完整根本原因分析過程。 本文也是您提高線程轉儲分析技能的絕佳機會&#xff0c;我強烈建議您學習并正確理解以下分析方法。 與過早的中間件&#xff08;Weblogic&#xff09;重…

java 可以重載等于號碼_Java面試之Java基礎4——重載與重寫的區別

目錄重載與重寫的概念重載與重寫的區別重載與重寫的總結構造器是否能被重寫override為什么函數不能根據返回類型來區分重載重載與重寫的概念重載&#xff1a;同樣一個方法可以根據輸入參數列表的不同&#xff0c;做出不同的處理。普通方法和構造器方法都能夠重載。方法重載&…

二維數組、多維數組

二維數組&#xff1a; 定義二維數組 int[,] myArray new int[幾個一維數組,數組中的個數]; 數組可以具有多個維度。例如&#xff0c;下列聲明創建一個四行兩列的二維數組(可以理解為4個1維數組&#xff0c;數組中包含2個元素)&#xff1a; int[,] myArray new int[4,2]; int[…

一張大圖片有多個小圖片

這個頁面也是我看到別人的寫的&#xff0c;感覺不錯&#xff0c;就自己留下了為了以后自己可以容易找到&#xff0c;也希望可以方便到別人。 寫這個頁面 需要注意的是&#xff1a; 1.寫每一個小圖片的位置時候&#xff0c;要用id,這樣等級就高了&#xff0c;不然不起作用。 2.因…

java中如何調用dal接口案例_關于Java:接口的目的

好吧&#xff0c;我認為接口是一種強制對象實現一定數量功能的方法&#xff0c;而不必使用繼承。有點像合同。我半明白他們的意思。但是&#xff0c;如果界面中的所有內容都是&#xff1a;public interface animal{void eat(object food);}它沒有這樣的實現&#xff0c;那么無論…

Android Studio混淆

這一篇說一下Android Studio的代碼混淆&#xff1a; 第一步&#xff1a;要想使混淆生效&#xff0c;要修改項目&#xff08;App&#xff09;下的build.gradle一處內容&#xff1a;minifyEnabled 的值 設置為true&#xff0c;當前項目就可以使用混淆了。 apply plugin: com.and…

內存訪問模式很重要

在高性能計算中&#xff0c;通常會說高速緩存未命中的代價是算法的最大性能損失。 多年來&#xff0c;處理器速度的提高大大超過了延遲到主內存的速度。 通過更寬的多通道總線&#xff0c;到主內存的帶寬已大大增加&#xff0c;但是延遲并未顯著減少。 為了掩蓋這種延遲&#x…

上傳頭像將光標去掉

οnfοcus"this.blur();" unselectable"on" οnfοcus"this.blur();"支持火狐&#xff0c;谷歌等主流瀏覽器 unselectable支持ie瀏覽器轉載于:https://www.cnblogs.com/jar-gon/p/6841239.html

java底層 文件操作_JAVA的文件操作【轉】

11.3 I/O類使用由于在IO操作中&#xff0c;需要使用的數據源有很多&#xff0c;作為一個IO技術的初學者&#xff0c;從讀寫文件開始學習IO技術是一個比較好的選擇。因為文件是一種常見的數據源&#xff0c;而且讀寫文件也是程序員進行IO編程的一個基本能力。本章IO類的使用就從…

JAVA多線程,真的能提高效率嗎

舉個栗子 比如挖一個隧道&#xff0c;有2種開工方法1、只在山的一頭挖&#xff0c;直至挖到山的另一頭&#xff0c;從而打通隧道&#xff0c;這可以看成是單線程 2、在山的兩頭挖&#xff0c;同時開工&#xff0c;最后在山的中間接通&#xff0c;從而打通隧道&#xff0c;這感覺…

Java 8:測試Lambda水

Java 8大約有一年的時間了&#xff0c;它具有我非常期待的語言功能&#xff1a; Lambda Expression 。 令人遺憾的是&#xff0c;另一個重要功能Java平臺模塊已延遲到Java9。但是&#xff0c;將lambda表達式&#xff08;或閉包&#xff09;添加到該語言中將使Java編程變得更好。…

java定義js函數_JS中可以先使用函數,然后再定義.

首先要說明的,下面這種方式是對的,雖然不知道為什么,很奇怪為什么可以先使用,再定義,希望有了解的人可以給個說法.hello(www.openj.cn);function hello(name){alert("hello " name)};本文首發于 http://blog.openj.cn下面的這種定義函數方式,對于寫一些比較復雜的代碼…

基于閥值的工作流引擎設計

最近在做工作流處理流程部分的工作&#xff0c;順便研究了一下工作流引擎的一些設計理念和原理。由于以前接觸過人工智能神經網絡的一些東西&#xff0c;發現工作流引擎和神經網絡還是頗有一些相似之處&#xff0c;都是滿足一定的條件下向下一個節點傳遞。在神經網絡的神經元中…