前言

\(prufer\)序列应该是一个比较实用的东西。

据\(hl666\)大佬说,一切与度数有关的树上计数问题,都可以用它以及它的性质来解决。

而听说\(ZJOI\)最近特别喜欢出计数题,所以有必要学一学。

转化\(1\):从无根树到\(prefur\)序列

现在,给你一棵树,我们要考虑如何把它变成\(prefur\)序列。

我们需要重复进行以下操作,直至树中只剩下两个点:

  • 找到一个度数为\(1\),且编号最小的点。(其中编号最小保证了后面将会提到的\(prufer\)序列的唯一对应性,同时也方便从\(prufer\)序列转化回无根树)
  • 把这个点的父亲节点加入序列,然后把这个点从树中删除。

然后我们就得到了一个长度为\(n-2\)的序列,这就是\(prufer\)序列。

所以它有什么实际意义呢?

我也不知道。

以上面的图为例,我们可以模拟这一过程如下:

  • 找到\(4\)号节点,将其父结点加入序列,然后将其删去。此时序列:\(\{2\}\)。
  • 找到\(5\)号节点,将其父结点加入序列,然后将其删去。此时序列:\(\{2,3\}\)。
  • 找到\(3\)号节点,将其父结点加入序列,然后将其删去。此时序列:\(\{2,3,1\}\)。
  • 找到\(6\)号节点,将其父结点加入序列,然后将其删去。此时序列:\(\{2,3,1,2\}\)。
  • 找到\(2\)号节点,将其父结点加入序列,然后将其删去。此时序列:\(\{2,3,1,2,1\}\)。

所以,最后得到的\(prufer\)序列就是\(\{2,3,1,2,1\}\)。

转化\(2\):从\(prufer\)序列到无根树

还是以刚才那棵树为例吧,我们要考虑如何把它的\(prefur\)序列变回它本身。

我们需要重复进行以下操作,直至点集中只剩下两个点:(初始化所有点都在点集中)

  • 取出\(prufer\)序列最前面的元素\(x\)。
  • 取出在点集中的、且当前不在\(prufer\)序列中的最小元素\(y\)。(这恰好呼应了前面提到过的选取编号最小的节点)
  • 在\(x,y\)之间连接一条边。(注意前面的取出相当于删除)

最后,我们在点集中剩下的两个点中连一条边。

显然这有\(n-1\)条边,且绝对不会形成环,因此它是一棵树,且就是原树。

以上面的序列为例,我们可以模拟这一过程如下:

  • 取出\(2,4\)连边。此时\(prufer\)序列:\(\{3,1,2,1\}\),点集:\(\{1,2,3,5,6,7\}\)。
  • 取出\(3,5\)连边。此时\(prufer\)序列:\(\{1,2,1\}\),点集:\(\{1,2,3,6,7\}\)。
  • 取出\(1,3\)连边。此时\(prufer\)序列:\(\{2,1\}\),点集:\(\{1,2,6,7\}\)。
  • 取出\(2,6\)连边。此时\(prufer\)序列:\(\{1\}\),点集:\(\{1,2,7\}\)。
  • 取出\(1,2\)连边。此时\(prufer\)序列:\(\{\}\),点集:\(\{1,7\}\)。

最后再在\(1,7\)间连边,就可以得到原树了。

\(prufer\)序列的性质及相关结论

讲了这么多,我们最关键的还是\(prufer\)序列的一些性质,以及与其有关的一些结论。(毕竟前面也提到过,我也不知道这东西有什么实际意义

  • 重要性质:\(prufer\)序列与无根树一一对应。

    这应该显然吧,通过前面的介绍应该可以直接得出。

    而由这个性质,我们才能推导出后面的结论。

  • 度数为\(d_i\)的节点会在\(prufer\)序列中出现\(d_i-1\)次

    当某个节点度数为\(1\)时,会直接被删掉,否则每少掉一个相邻的节点,它就会在序列中出现\(1\)次。

    因此共出现\(d_i-1\)次。

  • 一个\(n\)个节点的完全图的生成树个数为\(n^{n-2}\)。

    对于一个\(n\)个点的无根树,它的\(prufer\)序列长为\(n-2\),而每个位置有\(n\)种可能性,因此可能的\(prufer\)序列有\(n^{n-2}\)种。

    又由于\(prufer\)序列与无根树一一对应,因此生成树个数应与\(prufer\)序列种树相同,即\(n^{n-2}\)。

  • 对于给定度数为\(d_{1\sim n}\)的一棵无根树共有\(\frac{(n-2)!}{\prod_{i=1}^n(d_i-1)!}\)种情况

    由上面的性质可以知道,度数为\(d_i\)的节点会在\(prufer\)序列中出现\(d_i-1\)次。

    则就是要求出\(d_i-1\)个\(i(1\le i\le n)\)的全排列个数。

    而上面那个式子就是可重全排列公式。(即全排列个数除以重复元素内部的全排列个数

大致就是这些。

例题

下面有两道例题:【洛谷2290】[HNOI2004] 树的计数【洛谷2624】[HNOI2008] 明明的烦恼

实际上,这两道题都只用了由\(prufer\)序列所推导得到的结论,而没有真正构造\(prufer\)序列,应该也不算特别好的例题。。。

初识prufer序列的更多相关文章

  1. bzoj 1005 1211 prufer序列总结

    两道题目大意都是根据每个点的度数来构建一棵无根树来确定有多少种构建方法 这里构建无根树要用到的是prufer序列的知识 先很无耻地抄袭了一段百度百科中的prufer序列的知识: 将树转化成Prufer ...

  2. bzoj1211: prufer序列 | [HNOI2004]树的计数

    题目大意: 告诉你树上每个节点的度数,让你构建出这样一棵树,问能够构建出树的种树 这里注意数量为0的情况,就是 当 n=1时,节点度数>0 n>1时,所有节点度数相加-n!=n-2 可以通 ...

  3. [BZOJ1211][HNOI2004]树的计数(Prufer序列)

    题目:http://www.lydsy.com:808/JudgeOnline/problem.php?id=1211 分析: 关于无根树的组合数学问题肯定想到Prufer序列,类似bzoj1005那 ...

  4. 树的计数 + prufer序列与Cayley公式 学习笔记

    首先是 Martrix67 的博文:http://www.matrix67.com/blog/archives/682 然后是morejarphone同学的博文:http://blog.csdn.ne ...

  5. BZOJ 1211 HNOI2004 树的计数 Prufer序列

    题目大意:给定一棵树中全部点的度数,求有多少种可能的树 Prufer序列.详细參考[HNOI2008]明明的烦恼 直接乘会爆long long,所以先把每一个数分解质因数.把质因数的次数相加相减.然后 ...

  6. prufer序列笔记

    prufer序列 度娘的定义 Prufer数列是无根树的一种数列.在组合数学中,Prufer数列由有一个对于顶点标过号的树转化来的数列,点数为n的树转化来的Prufer数列长度为n-2. 对于一棵确定 ...

  7. BZOJ1430小猴打架——prufer序列

    题目描述 一开始森林里面有N只互不相识的小猴子,它们经常打架,但打架的双方都必须不是好朋友.每次打完架后,打架 的双方以及它们的好朋友就会互相认识,成为好朋友.经过N-1次打架之后,整个森林的小猴都会 ...

  8. 【XSY2519】神经元 prufer序列 DP

    题目描述 有\(n\)点,每个点有度数限制,\(\forall i(1\leq i\leq n)\),让你选出\(i\)个点,再构造一棵生成树,要求每个点的度数不超过度数限制.问你有多少种方案. \( ...

  9. prufer序列

    介绍 其实是\(pr\ddot{u}fer\)序列 什么是prufer序列? 我们认为度数为\(1\)的点是叶子节点 有一颗无根树,每次选出编号最小的叶子节点,加到当前prufer序列的后面,然后删掉 ...

随机推荐

  1. UltraEdit 21.3 增加 mssql, json 高亮

    1.  %appdata%\IDMComp\UltraEdit 2.  将msql2k.uew,  json.uew 放到 wordfiles 目录即可 msql2k   json的uew 下载地址如 ...

  2. PIXI 宝物猎人(7)

    介绍 ,本实例来自官网 代码结构 打开 treasureHunter.html 文件,你将会看到所有的代码都在一个大的文件里.下面是一个关于如何组织所有代码的概览: //Setup Pixi and ...

  3. (转)linux下进程的进程最大数、最大线程数、进程打开的文件数和ulimit命令修改硬件资源限制

    ulimit命令查看和更改系统限制 ulimit命令详解 ulimit用于shell启动进程所占用的资源,可以用来设置系统的限制 语法格式 ulimit [-acdfHlmnpsStvw] [size ...

  4. (转)netstat 命令详解

    netstat 命令详解  原文:https://www.cnblogs.com/xieshengsen/p/6618993.html netstat命令是一个监控TCP/IP网络的非常有用的工具,它 ...

  5. SQL Server 2008 SQL2012 SQL2014 收缩日志 清空删除大日志文件

    SQL2008 SQL2012 SQL2014 的收缩日志 由于SQL2008对文件和日志管理进行了优化,所以以下语句在SQL2005中可以运行但在SQL2008中已经被取消:(SQL2005)Bac ...

  6. unity监听键盘按键

    放在Update里面 if (Input.anyKeyDown) { foreach (KeyCode keyCode in Enum.GetValues(typeof(KeyCode))) { if ...

  7. 工作采坑札记:4. Hadoop获取InputSplit文件信息

    1. 场景 基于客户的数据处理需求,客户分发诸多小数据文件,文件每行代表一条记录信息,且每个文件以"类型_yyyyMMdd_批次号"命名.由于同一条记录可能存在于多个文件中,且处于 ...

  8. TFS2013 设置签出独占锁(转载)

    作者:晓菜鸟 出处:http://www.cnblogs.com/52XF/p/4239056.html 在使用TFS进行源代码管理的时候VS默认允许多个签出,但在团队开发中往往需要设置独占锁(排他锁 ...

  9. artDialog组件应用学习(二)

    一.没有操作选项的对话框 预览: html前台引入代码:(之后各种效果对话框引入代码致,调用方法也一样,就不一一写入) <script type="text/javascript&qu ...

  10. 【U1结业机试题】新闻内容管理系统:解析XML文件读取Html模版生成网页文件

    一.作业要求: 1.在xml文件中创建新闻节点news,包含标题.作者.日期.正文等信息 2.创建HTML模板文件 3.读取xml中所有新闻信息,并使用新闻信息替换模板文件中占位符,从而为每一条新闻生 ...