作者热门文章
- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
本题来自http://www.geeksforgeeks.org/construct-bst-from-given-preorder-traversa/
我可以想到下面的简单算法(类似于 Java 内部对 TreeMap 遵循的算法)
但我没有在谷歌或同一链接的任何地方看到它的提及。根据我的理解,它的时间复杂度将是 nlog(n)。我理解它并不比 O(n) 的第二种方法好,但比 O(n^2) 的第一种方法好,不是吗?
最佳答案
你是正确的,它比第一种方法更好,但第二种方法甚至更好,因为时间复杂度为 O(n)。
当您没有提前完成输入时,您建议的方法会更好,但是当您准备好完整输入时,您不必一一添加,这涉及查找每个节点的位置 (logn)。所以对于 n 个节点,它将是 nlog(n)
关于java - 从给定的前序遍历构造 BST?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39980181/
我是一名优秀的程序员,十分优秀!