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

剑指offer二十七之二叉搜索树与双向链表

时间:2017-10-11 14:11:48      阅读:96      评论:0      收藏:0      [点我收藏+]

标签:www.   中序   创建   hid   rmi   roo   treenode   int   www   

一、题目

  输入一棵二叉搜索树,将该二叉搜索树转换成一个排序的双向链表。要求不能创建任何新的结点,只能调整树中结点指针的指向。

二、思路

      对二叉搜索树中序遍历的结果即为排序的结果,在中序遍历的过程中,建立双向指针。详细过程见代码注释。

三、代码

技术分享
public class Solution {

    TreeNode tempHead = null; //
    TreeNode realHead = null; //保存双向链表的头结点

    public TreeNode Convert(TreeNode pRootOfTree) {
        //如果头结点为空,返回null
        if (pRootOfTree == null) {
            return null;
        }

        //转换
        ConvertMethod(pRootOfTree);

        //返回双向链表的头结点
        return realHead;
    }

    //采用递归的方法进行中序遍历,遍历过程中,建立头结点和下一个节点的双向指针
    public void ConvertMethod(TreeNode pRootOfTree) {
        //递归遍历左节点
        if (pRootOfTree.left != null) {
            ConvertMethod(pRootOfTree.left);
        }

        //建立根节点与下一个节点的双向指针
        if(tempHead==null){    //第一次运行的时候,头结点为空,初始化头结点
            tempHead=pRootOfTree;//用于记录当前头结点
            realHead=pRootOfTree;//用于记录双向链表的头结点
        }else {  //第一次运行以后,建立tempHead节点与其下一个节点的双向指针
           //建立当前头结点与下一个节点的双向指针
            tempHead.right = pRootOfTree;
            pRootOfTree.left = tempHead;

            tempHead = pRootOfTree; //当前头节点后移一位
        }

        //递归遍历右节点
        if (pRootOfTree.right != null) {
            ConvertMethod(pRootOfTree.right);
        }

    }
}
View Code
技术分享
public class TreeNode {
    int val = 0;
    TreeNode left = null;
    TreeNode right = null;

    public TreeNode(int val) {
        this.val = val;

    }

}
View Code

------------------------------------------------------

参考链接:https://www.nowcoder.com/questionTerminal/947f6eb80d944a84850b0538bf0ec3a5

剑指offer二十七之二叉搜索树与双向链表

标签:www.   中序   创建   hid   rmi   roo   treenode   int   www   

原文地址:http://www.cnblogs.com/hezhiyao/p/7650067.html

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