题目描述:
输入一棵二叉搜索树,将该二叉搜索树转换成一个排序的双向链表。要求不能创建任何新的结点,只能调整树中结点指针的指向。
题解:
class Solution {
public:
TreeNode *pre = NULL;
TreeNode* Convert(TreeNode* pRootOfTree)
{
if(pRootOfTree == NULL)
return NULL;
Convert(pRootOfTree->right);
if(pre)
{
pre->left = pRootOfTree;
pRootOfTree->right = pre;
}
pre = pRootOfTree;
Convert(pRootOfTree->left);
return pre;
}
};
解题思路:
中序遍历,left和right当双向链表的前项指针和后向指针。