(*)剑指offer 面试题27:二叉搜索时与双向链表

题目:
输入一颗二叉搜索树,将该二叉搜索树转换成一个排序的双向链表。要求不能创建任何新的结点,只能调整树中结点指针的指向。

struct binaryTreeNode {
    int                                  m_nValue;
    binaryTreeNode*            m_pLeft;
    binaryTreeNode*            m_pRight;
};

解法:
分析:二叉搜索树的特点:左子树都比根小,右子树都比根大。对于根结点,它的上一个结点即为左子树中最大的那个结点,下一个结点即为右子树中最小的结点

void convertNode(binaryTreeNode* pRoot, binaryTreeNode** pLastNodeInList) {
    if (pRoot == 0)    return;
    binaryTreeNode  *pCurrent = pRoot;
    if (pCurrent->m_pLeft) {
        convertNode(pCurrent->m_pLeft, pLastNodeInList);
    }
    pCurrent->m_pLeft = *pLastNodeInList;
    if (*pLastNodeInList != 0) {
        (*pLastNodeInList)->m_pRight = pCurrent;
    }
    *pLastNodeInList = pCurrent;
    if (pCurrent->m_pRight) {
        convertNode(pCurrent->m_pRight, pLastNodeInList);
    }
}
binaryTreeNode*  convert(binaryTreeNode* pRoot) {
    binaryTreeNode* pLast = 0;
    convertNode(pRoot, &pLast);
    while (pLast != 0 && pLast->m_pLeft != 0) {
        pLast = pLast->m_pLeft;
    }
    return pLast;
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 概述# 二叉树是一种特殊的树型结构,它由结点的有限集合构成。 二叉树是由唯一的起始结点引出的结点集合。这个起始节点...
    长胖的鱼阅读 4,870评论 0 8
  • 数据结构与算法--从平衡二叉树(AVL)到红黑树 上节学习了二叉查找树。算法的性能取决于树的形状,而树的形状取决于...
    sunhaiyu阅读 12,280评论 4 32
  • 1. 链表 链表是最基本的数据结构,面试官也常常用链表来考察面试者的基本能力,而且链表相关的操作相对而言比较简单,...
    Mr希灵阅读 10,959评论 1 17
  • 数据结构与算法--二叉查找树 上节中学习了基于链表的顺序查找和有序数组的二分查找,其中前者在插入删除时更有优势,而...
    sunhaiyu阅读 6,220评论 0 9
  • 总结 想清楚再编码 分析方法:举例子、画图 第1节:画图分析方法 对于二叉树、二维数组、链表等问题,都可以采用画图...
    M_巴拉巴拉阅读 4,979评论 0 7

友情链接更多精彩内容