码迷,mamicode.com
首页 > 其他好文 > 详细

九:二叉搜索树与双向链表(二叉搜索树转为有序双向链表)

时间:2015-07-10 11:26:22      阅读:118      评论:0      收藏:0      [点我收藏+]

标签:二叉搜索树与双向链表   二叉搜索树转为有序双向链表   双向链表与二叉搜索树   

问题描述:

输入一棵二叉搜索树,现在要将该二叉搜索树转换成一个排序的双向链表。而且在转换的过程中,不能创建任何新的结点,只能调整树中的结点指针的指向来实现。

 

解析:

借助二叉树中序遍历,因为中序遍历二叉搜索树的特点就是从小到大访问结点。当遍历访问到根结点时,假设根结点的左侧已经处理好,只需将根结点与上次访问的最近结点(左子树中最大值结点)的指针连接好即可。进而更新当前链表的最后一个结点指针。

 

递归算法:

(1)中序遍历。

(2)原先指向左子结点的指针调整为链表中指向前一个结点的指针,原先指向右子结点的指针调整为链表中指向下一个结点的指针。

 

代码如下:

void ConvertNode(BinaryTreeNode* pNode,BinaryTreeNode** pLastNodeInList)

{

    if(pNode ==NULL)

        return;

 

BinaryTreeNode *pCurrent = pNode;

 

//中序遍历

    if(pCurrent->m_pLeft != NULL)

       ConvertNode(pCurrent->m_pLeft, pLastNodeInList);

 

//原先指向左子结点的指针调整为链表中指向前一个结点的指针

pCurrent->m_pLeft = *pLastNodeInList;

 

//原先指向右子结点的指针调整为链表中指向下一个结点的指针

   if(*pLastNodeInList != NULL)

       (*pLastNodeInList)->m_pRight = pCurrent;

 

//更新当前链表的最后一个结点指针

   *pLastNodeInList = pCurrent;

 

    if(pCurrent->m_pRight != NULL)

        ConvertNode(pCurrent->m_pRight,pLastNodeInList);

}

 

BinaryTreeNode* Convert(BinaryTreeNode* pRootOfTree)

{

   BinaryTreeNode *pLastNodeInList = NULL;

   ConvertNode(pRootOfTree, &pLastNodeInList);

 

 //pLastNodeInList指向双向链表的尾结点,我们需要返回头结点

   BinaryTreeNode *pHeadOfList = pLastNodeInList;

   while(pHeadOfList != NULL && pHeadOfList->m_pLeft != NULL)

       pHeadOfList = pHeadOfList->m_pLeft;

 

    return pHeadOfList;

}

 

版权声明:本文为博主原创文章,未经博主允许不得转载。

九:二叉搜索树与双向链表(二叉搜索树转为有序双向链表)

标签:二叉搜索树与双向链表   二叉搜索树转为有序双向链表   双向链表与二叉搜索树   

原文地址:http://blog.csdn.net/day__day__up/article/details/46827265

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!