[蓝桥杯知识学习] 树链

DFS序

什么是DFS序

怎么求DFS序

进入操作,将有计数++

出:可以理解为,没有孩子可以去了(不能,向下行动:对应于程序里的入栈),所以回到父结点(向上行动,对应于程序里的出栈)

总体行动:

  1. 进入结点,计数++,赋值:入=当前计数

  2. 如果可以向下,则重复1操作

  3. 如果没有可以向下的了,则,在当前结点:赋值出=当前计数,回到父结点,重复2操作

代码实现

我自己写的,更好懂

cpp 复制代码
//多叉树
int inn[100000];  //dfs入序
int out[100000];   //dfs出序
int weight[100000];  //权重
vector<int> edge[100000];  //用来放结点的子结点
int cnt;  //dfs序计数器

//生成dfs序
void dfs(int t,int f)
{
  inn[t] = ++cnt;
  for(int i = 0 ; i < edge[t].size() ; i++)
  {
    dfs(edge[t][i],t);
  }
  out[t] = cnt;
  return ;
}

其实就是三段论

用一个数组 in 存放该结点的入序,遍历这个结点所有的子结点,用一个数组 out 放出序

DFS序的性质

  1. 某些连续的入序对应树中的节点是一条链

2.某节点入序和出序之间对应的节点一定在其子树中

某结点的子树,其子树上的结点入序数都大于该结点,出序数都小于该结点。(这个好理解,要先进入这个结点,才能向下;向上的话,这个结点在最上方)

出序,一路退出,和最后进入的结点计数值相同

int < t的子树的DFS序 < outt

例题

涉及到子树,所以用DFS序

解释,为什么第一个操作用的是 inx (某点的DFS序值),因为我们使用DFS序值当作数组下标,来记录点的点权,方便第二个操作的进行。

解释第二个操作:使用DFS序的第二个性质,inx 与 outx 之间是x子树结点的DFS序。

相关推荐
-To be number.wan8 小时前
计算机组成原理 | SRAM与DRAM
学习·计算机组成原理
朔北之忘 Clancy9 小时前
2026 年 3 月青少年软编等考 C 语言二级真题解析
c语言·开发语言·c++·学习·青少年编程·题解·考级
Upsy-Daisy9 小时前
IOTA 学习笔记(四):当前 IOTA 架构总览
笔记·学习·架构
小拉达不是臭老鼠10 小时前
Unity中的UI系统之UGUI
学习·ui·unity
吃好睡好便好10 小时前
矩阵的转置运算
学习·线性代数·matlab·矩阵
爱上好庆祝10 小时前
学习JS第十三天
学习
魔法阵维护师11 小时前
从零开发游戏需要学习的c#模块,第三十四章(设置界面)
学习·游戏·c#
FserSuN12 小时前
Machine Learning Specialization - Week 1, 9-20学习总结
人工智能·学习·机器学习
OBiO201312 小时前
肺部靶向 AAV 怎么选?如何解决靶向不精准、转导效率低的递送难题?
学习
我命由我1234512 小时前
UGC、PGC、PUGC 极简理解
经验分享·笔记·学习·职场和发展·求职招聘·职场发展·学习方法