算法-如何合并两个二分查找树。

发布于 2017-02-03 09:44:57 字数 30 浏览 1254 评论 2

空间和时间复杂度不好估计,当然求一个最优思路。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

夜无邪 2017-04-28 13:59:31

分享一个递归算法:

template<class T>
class BinaryTree
{
struct Node
{
T data;
Node * left, * right;
} * root;
public:
void add(const T & value);
void combine(Node * r);
};

template<class T>
void BinaryTree<T>::combine(Node * r)
{
if(r == 0)return;
if(r->left != 0)combine(r->left);
if(r->right != 0)combine(r->right);
add(r->data);
}

泛泛之交 2017-04-20 14:51:21

分三步:
1.将二叉树转换成已序链表。
2.将两个已序链表合并成一个链表。
3.将合并后的链表再次转换成二叉查找树。

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文