美文网首页
LinkedList:将二叉搜索树转换成双向链表

LinkedList:将二叉搜索树转换成双向链表

作者: 敲一手烂代码 | 来源:发表于2016-05-18 13:47 被阅读0次
public static BinTreeNode BSTToDoubleLinkedList(BinTreeNode head) {
        Queue<BinTreeNode> queue = new LinkedList<BinTreeNode>();
        inOrderToQueue(head, queue);
        head = queue.poll();
        BinTreeNode pre = head;
        head.left = null;
        while (!queue.isEmpty()) {
            BinTreeNode cur = queue.poll();
            pre.right = cur;
            cur.left = pre;
            pre = cur;
        }
        pre.right = null;
        return head;
    }
    public static void inOrderToQueue(BinTreeNode head,Queue<BinTreeNode> queue) {
        if (head == null) {
            return;
        }
        inOrderToQueue(head.left, queue);
        queue.add(head);
        inOrderToQueue(head.right, queue);
    }

相关文章

网友评论

      本文标题:LinkedList:将二叉搜索树转换成双向链表

      本文链接:https://www.haomeiwen.com/subject/rmrwrttx.html