树论的一些总结

树是 OI 中一种常见于题面与算法中的玩意,兼具美丽与恶心的特性。树作为一张图的子集,它与图的关系紧密;而本身作为一种数据结构,又承担储存、组织数据的责任。
ㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤ——老师

基本概念

树可以理解为一种数据结构,是由 n ( n ≥ 1 ) n(n \geq 1) n(n1)个有限节点组成的一个具有层次关系的集合。
有根树一般存在有以下特点:

  • 有一个节点被称作
  • 这个根的所有孩子都是一棵子树的根

与有根树相关联的概念:

  • 父亲:对于除根以外的每个节点,定义为该节点到根路径上的第二个节点。根节点没有父节点。
  • 祖先:一个节点到根节点的路径上,除了它本身外的节点。根节点的祖先集合为空。
  • 子节点:如果 u u u v v v的父亲,那么 v v v u u u的子节点。
  • 节点深度:到根节点的路径上的边数。
  • 树的高度:所有节点的深度的最大值。
  • 兄弟:同一个父亲的多个子节点互为兄弟。

除了有根树,还有无根树
在处理与之相关的问题时,可以看作 n n n个节点与 n − 1 n-1 n1条边的无向图。
如果在无根树上指定一个节点为“根”,则满足了有根树的性质。
科普:

有根树在很多时候仍以无向图表示,只是规定了结点之间的上下级关系。
往往我们还有遇到一些带有特殊性质的树。例如二叉树、完全二叉树、慢二叉树、仙人掌等等,这些树的属性又赋予了他们处理不同问题的功能。

树上问题

D F S DFS DFS

定义:对于一棵树来说, D F S DFS DFS 序即按照深度优先搜索的访问顺序,依次将访问到的点进行编号并记录根据访问顺序取得的序列 即为 D F S DFS DFS 序。
深度优先搜索,即 D e p t h   F i r s t   S e a r c h Depth~First~Search Depth First Search,简称 D F S DFS DFS或深搜。

得出一棵树的 D F S DFS DFS 序后,对它的处理便可以向线性问题靠拢。这是一个很重要的思想。将复杂的结构通过一定的方式简化,使其变得线性,更加容易处理。

B F S BFS BFS

定义:对于一棵树来说, B F S BFS BFS 序即按照广度优先搜索的访问顺序,依次将访问到的点进行编号并记录根据访问顺序取得的序列 即为 B F S BFS BFS 序。
广度优先搜索:又称宽度优先搜索,即 B r e a d t h   F i r s t   S e a r c h Breadth~First~Search Breadth First Search,简称 B F S BFS BFS、广搜或宽搜。

D F S   B F S DFS~BFS DFS BFS总结:

  1. dfs序中一个结点的子树结点一定是连续的。
  2. bfs,dfs序中的一个结点u的后续结点一定是u或u的后兄弟结点{v},或u和{v}的后代节点{s}。
  3. 如果有后兄弟结点,那么bfs序中u后面紧跟着的一定是第一后兄弟结点v1,
  4. 如果有后代结点,那么dfs序中u后面紧跟着的一定是第一个子结点s1。

前序、中序、后序排列

定义:

  1. 前序遍历
    • 先输出父结点,再左结点,最后右结点(父左右)
  2. 中序遍历
    • 先输出左结点,再父结点,最后右结点(左父右)
  3. 后序遍历
    • 先左结点,再右结点,最后父结点(左右父)

例如:
20201009143355220.png

前序:ABDGHICEJF
中序:GDIHBAEJCF
后序:GIHDBJEFCA

树的直径

定义:树上任意两节点之间存在的最长简单路径,就被称作树的直径。
可以用两次 D F S DFS DFS、两次 B F S BFS BFS或者树形 D P DP DP进行求解。

最近公共祖先( L o w e s t   C o m m o n   A n c e s t o r Lowest~Common~Ancestor Lowest Common Ancestor

定义:最近公共祖先,简称 L C A LCA LCA,也就是两个节点的公共祖先中,距离“根节点”最远的那一个节点
可以用向上标记法、树上倍增法、 T a r j a n Tarjan Tarjan算法、树链剖分、欧拉序+ s t st st表等算法进行求解。

树的重心

定义:重心是指树中的一个结点,如果将这个点删除后,剩余各个连通块中点数的最大值最小,那么这个节点被称为树的重心。
这里以及下文中的“子树”都是指无根树的子树,即包括“向上”的那棵子树,并且不包括整棵树自身

一些性质:

  • 以树的重心为根,所有子树的大小都不超过整棵树大小的一半。
  • 树中所有点到某个点的距离和中,到重心的距离和是最小的。如果有两个重心,那么到它们的距离和一样。
  • 把两棵树通过一条边相连得到一棵新的树,那么新的树的重心在连接原来两棵树的重心的路径上。
  • 在一棵树上添加或删除一个叶子,那么它的重心最多只移动一条边的距离。

求法:见AcWing 846. 树的重心

最小生成树

生成树定义:一个连通图的生成子图,同时要求是树。即在图的边集中选择 n − 1 n-1 n1条边,将所有顶点连通。
最小生成树定义:即权值和最小的生成树。

只有连通图才有生成树,而对于非连通图,只存在生成森林。

主要求解方法: P r i m Prim Prim K r u s k a l Kruskal Kruskal B o r u v k a Boruvka Boruvka

  • K r u s k a l Kruskal Kruskal 算法的基本思想是从小到大加入边,核心是贪心算法。
  • P r i m Prim Prim 算法是另一种常见并且好写的最小生成树算法。基本思想是从一个点出发,不断加点。
  • B o r u v k a Boruvka Boruvka 的思想则可以看作二者的结合。

树链剖分

  • 21
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值