九:二叉搜索树与双向链表(二叉搜索树转为有序双向链表)
2016-02-17 15:43
337 查看
问题描写叙述:
输入一棵二叉搜索树,如今要将该二叉搜索树转换成一个排序的双向链表。
并且在转换的过程中,不能创建不论什么新的结点。仅仅能调整树中的结点指针的指向来实现。
解析:
借助二叉树中序遍历,由于中序遍历二叉搜索树的特点就是从小到大訪问结点。当遍历訪问到根结点时。如果根结点的左側已经处理好。仅仅需将根结点与上次訪问的近期结点(左子树中最大值结点)的指针连接好就可以。进而更新当前链表的最后一个结点指针。
递归算法:
(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;
}
输入一棵二叉搜索树,如今要将该二叉搜索树转换成一个排序的双向链表。
并且在转换的过程中,不能创建不论什么新的结点。仅仅能调整树中的结点指针的指向来实现。
解析:
借助二叉树中序遍历,由于中序遍历二叉搜索树的特点就是从小到大訪问结点。当遍历訪问到根结点时。如果根结点的左側已经处理好。仅仅需将根结点与上次訪问的近期结点(左子树中最大值结点)的指针连接好就可以。进而更新当前链表的最后一个结点指针。
递归算法:
(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;
}
相关文章推荐
- linux命令:mv命令
- 【CodeForces 613A】Peter and Snow Blower
- Eclipse搭建SSH(Struts2+Spring3+Hibernate3)开发项目
- 通过一个实例学会时间复杂度的计算
- ValidationAttribute
- NDK 开发实例
- POJ3254 Corn Fields(状压DP)
- 【BZOJ 3224】普通平衡树 模板题
- return ture & return false
- 20160217 更新物业收费管理
- TableViewCell加动画
- archive的时候报“ no identity found"错,怎么办?
- power designer导出word或html
- 彻底解决Spring MVC 中文乱码 问题
- 深入分析MySQL ERROR 1045 (28000)
- Nancy之Forms authentication的简单使用
- 在MainActivity的内部静态类PlaceholderFragment 类中的onCreateView中获取fragment_main.xml中控件
- 计算进位次数
- gerrit添加新用户
- log4j.properties配置详解