码迷,mamicode.com
首页 > 其他好文 > 详细

二叉搜索树转双向链表

时间:2018-07-07 12:42:38      阅读:162      评论:0      收藏:0      [点我收藏+]

标签:代码   ret   The   nod   nullptr   搜索   oid   pre   turn   

直接通过中序遍历来解。但是需要设置两个节点记录每个子树排序后的第一和最后一个节点,尤其是最后一个,因为最后一个节点是由于连接所需。

上代码:

class Solution {
public:
   
    TreeNode* Convert(TreeNode* pRootOfTree)
    {
        TreeNode* head=NULL;//每个子树排序后的第一个节点
        TreeNode* tail=NULL;//每个子树排序后的最后一个节点
        ConvertHelp(pRootOfTree,head,tail);
        return head;
    }
 void ConvertHelp(TreeNode* pRootOfTree,TreeNode* &head,TreeNode* &tail) {
     if(pRootOfTree==NULL) return;
     ConvertHelp(pRootOfTree->left,head,tail);
     if (tail == NULL) {//说明找到了中序遍历的第一个节点,把其作为链表头节点
         tail = pRootOfTree;
         head = pRootOfTree;
     } else {
         tail->right = pRootOfTree;
         pRootOfTree->left = tail;
         tail = pRootOfTree;
     }
     ConvertHelp(pRootOfTree->right,head,tail);
    }
};

法二:(思路同上,但是更简洁)

class Solution {
public:
    TreeNode* Convert(TreeNode* pRootOfTree)
    {
        if(pRootOfTree == nullptr) return nullptr;
        TreeNode* pre = nullptr;
         
        convertHelper(pRootOfTree, pre);
         
        TreeNode* res = pRootOfTree;
        while(res ->left)
            res = res ->left;
        return res;
    }
     
    void convertHelper(TreeNode* cur, TreeNode*& pre)
    {
        if(cur == nullptr) return;
         
        convertHelper(cur ->left, pre);
         
        cur ->left = pre;
        if(pre) pre ->right = cur;
        pre = cur;
         
        convertHelper(cur ->right, pre);
         
         
         
    }
};

 

二叉搜索树转双向链表

标签:代码   ret   The   nod   nullptr   搜索   oid   pre   turn   

原文地址:https://www.cnblogs.com/inception6-lxc/p/9276684.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!