首页 > 其他 > 详细

二叉搜索树——剑指 Offer 36. 二叉搜索树与双向链表

时间:2021-04-22 15:23:35      阅读:13      评论:0      收藏:0      [点我收藏+]

二叉搜索树——剑指 Offer 36. 二叉搜索树与双向链表

题目:

技术分享图片

思路:

二叉搜索树,自然就是中序遍历,然后就是构建双向链表就可以了。构建双向链表部分有点忘记,又看了看才明白。然后就干就好了。

代码:

class Solution {
public:
    Node* treeToDoublyList(Node* root) {
        if(root == nullptr) return nullptr;
        Node* head = nullptr, *tail = nullptr;
        //  中序遍历
        build(root, head, tail);
        head->left = tail;
        tail->right = head;
        return head;
    }

    void build(Node* root, Node* &head, Node* &tail){
        if(root){
            // 左
            build(root->left, head, tail);
            // 中
            if(head == nullptr){
                head = tail = root;
            }else{
                tail->right = root;
                root->left = tail;
                tail = root;
            }
            // 右
            build(root->right, head, tail);
        }
    }
};

Rank:

技术分享图片

Tips

就是复习一下链表部分,剩下就没啥了。

二叉搜索树——剑指 Offer 36. 二叉搜索树与双向链表

原文:https://www.cnblogs.com/lzyrookie/p/14687958.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!