输入一棵二叉搜索树,将该二叉搜索树转换成一个排序的双向链表。如下图所示
注意:
1.要求不能创建任何新的结点,只能调整树中结点指针的指向。当转化完成以后,树中节点的左指针需要指向前驱,树中节点的右指针需要指向后继
2.返回链表中的第一个节点的指针
3.函数返回的TreeNode,有左右指针,其实可以看成一个双向链表的数据结构
4.你不用输出双向链表,程序会根据你的返回值自动打印输出
import java.util.Stack;
public class Solution {
TreeNode head, pre;
public TreeNode Convert(TreeNode node) {
if (node == null) {
return null;
}
dfs(node);
return head;
}
public void dfs(TreeNode node) {
if (node.left != null) {
dfs(node.left);
}
if (pre != null) {
pre.right = node;
} else {
//这一个只在第一步执行
head = node;
}
//双向链表指向
node.left = pre;
//再赋值新的节点
pre = node;
if (node.right != null) {
dfs(node.right);
}
}
}