Posted on 2014-01-03 00:41
whspecial 阅读(3605)
评论(0) 编辑 收藏 引用 所属分类:
算法&&数据结构
将排序二叉树转化成双向链表,应该是一道很常见的面试题目,网上的实现比较多,有用递归也有用中序遍历法的。看到一位外国友人的实现,还是比较清晰的,思路如下:
1,如果左子树不为null,处理左子树
1.a)递归转化左子树为双向链表;
1.b)找出根结点的前驱节点(是左子树的最右的节点)
1.c)将上一步找出的节点和根结点连接起来
2,如果右子树不为null,处理右子树(和上面的很类似)
1.a)递归转化右子树为双向链表;
1.b)找出根结点的后继节点(是右子树的最左的节点)
1.c)将上一步找出的节点和根结点连接起来
3,找到最左边的节点并返回
附上国外友人的链接:http://www.geeksforgeeks.org/in-place-convert-a-given-binary-tree-to-doubly-linked-list/
下面是代码实现:
bintree2listUtil函数返回的node* 是root节点,bintree2list函数返回的是头节点
node* bintree2listUtil(node* root)
{
if
(root == NULL)
return
root;
if
(root->left != NULL)
{
node* left = bintree2listUtil(root->left);
for
(; left->right!=NULL; left=left->right);
left->right = root;
root->left = left;
}
if
(root->right!=NULL)
{
node* right = bintree2listUtil(root->right);
for
(; right->left!=NULL; right = right->left);
right->left = root;
root->right = right;
}
return
root;
}
node* bintree2list(node *root)
{
if
(root == NULL)
return
root;
root = bintree2listUtil(root);
while
(root->left != NULL)
root = root->left;
return
(root);