作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试了解 Euler Tour 算法以及为什么它在树遍历中很受欢迎。但是,我看不出 Euler Tour 和树的预序遍历之间的区别。
假设你有一棵树:
A
/ \
B E
/ \ \
C D F
如果您执行欧拉游览算法,它将是:
A -> B -> C -> B -> D -> B -> A -> E -> F -> E -> A
但是这样做的目的是什么?它看起来就像是完全相同版本的递归预购:
A -> B -> C -> D -> E -> F
显然,在 Euler Tour 中,每个节点值在路径中至少出现两次,但这只是由于编程时算法的递归性质所致。如果您愿意,您可以进行与 Euler Tour 相同的计算...通过预订,对吗?
如果有人可以帮助解释 Euler Tour 以及为什么使用它而不是其他遍历,我们将非常感激。谢谢。
最佳答案
通过欧拉之旅,您可以从结果中获取更多信息。
例如,您可以查看节点是否是叶子。如果节点的前任节点和后继节点相同,就会出现这种情况。
此外,您还可以通过为每个前向支路的计数器加 +1 并为每个后向支路减去 1 来计算节点的深度。
在处理算法中的树时,这些信息通常很有用。
关于data-structures - Euler Tour算法和前序遍历本质上是一样的吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39900773/
序 大家好呀,我是summo,这次来写写我在上班空闲(摸鱼)的时候做的一个小网站的事。去年阿里云不是推出了个活动嘛,2核2G的云服务器一年只要99块钱,懂行的人应该知道这个价格在业界已经是非常良心了
我尝试根据给定的级别顺序(BFS 顺序)构造 BST。我知道这是可能的,但我不知道我该怎么写。问题是我必须使用 BFS 序列。所以,我不能在这里使用递归,我必须迭代地编写我的程序......我发现这有
我是一名优秀的程序员,十分优秀!