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
网友评论