[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.mzph.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;都是满足一定的条件下向下一个节点传递。在神经网络的神经元中…