作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
通常,如果使用深度优先遍历,我们会得到 O(n)
时间。但是,如果我们先找到最小元素然后调用 successor()
方法 n
次,时间复杂度是多少?
我想可能是O(n log n)
因为继任者是 O(log n)
但这似乎不对。任何人都可以在这里提供任何深入的分析(可能涉及一些极限分析)?
最佳答案
如果每个节点都存在父指针,则调用后继方法 n 次需要 O(n) 时间。要看到这一点,请观察树中的每条边最多被所有后继调用访问两次(一次从父级到子级,一次从子级到父级)。因此,所有后继调用所访问的边总数最多为 2n。所以运行时间是O(n)。
现在,如果父指针不存在,在每次调用中,我们必须从根开始并通过遍历 O(log n) 个节点(如果树是平衡的)来搜索后继元素。所以复杂度变成了 O(n log n)。
关于以这种方式实现的 BST 中序遍历的时间复杂度,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12447499/
序 大家好呀,我是summo,这次来写写我在上班空闲(摸鱼)的时候做的一个小网站的事。去年阿里云不是推出了个活动嘛,2核2G的云服务器一年只要99块钱,懂行的人应该知道这个价格在业界已经是非常良心了
我尝试根据给定的级别顺序(BFS 顺序)构造 BST。我知道这是可能的,但我不知道我该怎么写。问题是我必须使用 BFS 序列。所以,我不能在这里使用递归,我必须迭代地编写我的程序......我发现这有
我是一名优秀的程序员,十分优秀!