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

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);
    }
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容