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:将二叉搜索树转换成双向链表
最后编辑于 :
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
推荐阅读更多精彩内容
- Convert Sorted List to Binary Search Tree。Given a singly ...