二叉搜索树与双向链表

本贴最后更新于 2452 天前,其中的信息可能已经天翻地覆

题目描述

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

解题思路

利用二叉树的中序遍历:

  • 首先一直读取左链表,压入栈。

  • 读取栈内最上面的值,此结点即为此时的最小值。

  • 本结点的左链为上一结点,上一结点的右链为本结点。

  • 检查本结点是否有右子树

    • 如果有右子树,那么对右子树重复本循环。

    • 如果没有右子树,那么回到读取栈值。

代码

import java.util.Stack;
public class Solution {
    public TreeNode Convert(TreeNode pRootOfTree) {
        if (pRootOfTree == null)
            return pRootOfTree;
        Stack<TreeNode> stack = new Stack<>();
        TreeNode pre = null;
        TreeNode head = null;
        while (!stack.isEmpty() || pRootOfTree != null) {
            while (pRootOfTree != null) {
                stack.push(pRootOfTree);
                pRootOfTree = pRootOfTree.left;
            }
            pRootOfTree = stack.pop();
            pRootOfTree.left = pre;
            if (pre != null)
                pre.right = pRootOfTree;
            if (head == null)
                head = pRootOfTree;
            pre = pRootOfTree;
            pRootOfTree = pRootOfTree.right;
        }
        return head;
    }
}

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...