php数据结构之二叉树

树是一种比较重要的数据结构, 尤其是二叉树。二叉树是一种特殊的树,在二叉树中每个节点最多有两个子节点,一般称为左子节点和右子节点(或左孩子和右孩子),并且二叉树的子树有左右之 分,其次序不能任意颠倒。二叉树是递归定义的,因此,与二叉树有关的题目基本都可以用递归思想解决,当然有些题目非递归解法也应该掌握,如非递归遍历节点 等等。本文努力对二叉树相关题目做一个较全的整理总结,希望对找工作的同学有所帮助。

二叉树节点定义如下:

struct BinaryTreeNode

{

int m_nValue;

BinaryTreeNode* m_pLeft;

BinaryTreeNode* m_pRight;

};

相关链接:

轻松搞定面试中的链表题目

题目列表:

1. 求二叉树中的节点个数

2. 求二叉树的深度

3. 前序遍历,中序遍历,后序遍历

4.分层遍历二叉树(按层次从上往下,从左往右)

5. 将二叉查找树变为有序的双向链表

6. 求二叉树第K层的节点个数

7. 求二叉树中叶子节点的个数

8. 判断两棵二叉树是否结构相同

9. 判断二叉树是不是平衡二叉树

10. 求二叉树的镜像

11. 求二叉树中两个节点的最低公共祖先节点

12. 求二叉树中节点的最大距离

13. 由前序遍历序列和中序遍历序列重建二叉树

14.判断二叉树是不是完全二叉树

详细解答

1. 求二叉树中的节点个数

递归解法:

(1)如果二叉树为空,节点个数为0

(2)如果二叉树不为空,二叉树节点个数 = 左子树节点个数 + 右子树节点个数 + 1

参考代码如下:

    int GetNodeNum(BinaryTreeNode * pRoot)
    {
        if(pRoot == NULL) // 递归出口
            return 0;
        return GetNodeNum(pRoot->m_pLeft) + GetNodeNum(pRoot->m_pRight) + 1;
    }  

2. 求二叉树的深度

递归解法:

(1)如果二叉树为空,二叉树的深度为0

(2)如果二叉树不为空,二叉树的深度 = max(左子树深度, 右子树深度) + 1

参考代码如下:

    int GetDepth(BinaryTreeNode * pRoot)
    {
        if(pRoot == NULL) // 递归出口
            return 0;
        int depthLeft = GetDepth(pRoot->m_pLeft);
        int depthRight = GetDepth(pRoot->m_pRight);
        return depthLeft > depthRight ? (depthLeft + 1) : (depthRight + 1);
    }  

3. 前序遍历,中序遍历,后序遍历

前序遍历递归解法:

(1)如果二叉树为空,空操作

(2)如果二叉树不为空,访问根节点,前序遍历左子树,前序遍历右子树

参考代码如下:

void PreOrderTraverse(BinaryTreeNode * pRoot)
{
    if(pRoot == NULL)
        return;
    Visit(pRoot); // 访问根节点
    PreOrderTraverse(pRoot->m_pLeft); // 前序遍历左子树
    PreOrderTraverse(pRoot->m_pRight); // 前序遍历右子树
}

中序遍历递归解法

(1)如果二叉树为空,空操作。

(2)如果二叉树不为空,中序遍历左子树,访问根节点,中序遍历右子树

参考代码如下:

    void InOrderTraverse(BinaryTreeNode * pRoot)
    {
        if(pRoot == NULL)
            return;
        InOrderTraverse(pRoot->m_pLeft); // 中序遍历左子树
        Visit(pRoot); // 访问根节点
        InOrderTraverse(pRoot->m_pRight); // 中序遍历右子树
    }  

后序遍历递归解法

(1)如果二叉树为空,空操作

(2)如果二叉树不为空,后序遍历左子树,后序遍历右子树,访问根节点

参考代码如下:

    void PostOrderTraverse(BinaryTreeNode * pRoot)
    {
        if(pRoot == NULL)
            return;
        PostOrderTraverse(pRoot->m_pLeft); // 后序遍历左子树
        PostOrderTraverse(pRoot->m_pRight); // 后序遍历右子树
        Visit(pRoot); // 访问根节点
    }  

4.分层遍历二叉树(按层次从上往下,从左往右)

相当于广度优先搜索,使用队列实现。队列初始化,将根节点压入队列。当队列不为空,进行如下操作:弹出一个节点,访问,若左子节点或右子节点不为空,将其压入队列。

    void LevelTraverse(BinaryTreeNode * pRoot)
    {
        if(pRoot == NULL)
            return;
        queue<BinaryTreeNode *> q;
        q.push(pRoot);
        while(!q.empty())
        {
            BinaryTreeNode * pNode = q.front();
            q.pop();
            Visit(pNode); // 访问节点
            if(pNode->m_pLeft != NULL)
                q.push(pNode->m_pLeft);
            if(pNode->m_pRight != NULL)
                q.push(pNode->m_pRight);
        }
        return;
    }  

5. 将二叉查找树变为有序的双向链表

要求不能创建新节点,只调整指针。

递归解法:

(1)如果二叉树查找树为空,不需要转换,对应双向链表的第一个节点是NULL,最后一个节点是NULL

(2)如果二叉查找树不为空:

如果左子树为空,对应双向有序链表的第一个节点是根节点,左边不需要其他操作;

如果左子树不为空,转换左子树,二叉查找树对应双向有序链表的第一个节点就是左子树转换后双向有序链表的第一个节点,同时将根节点和左子树转换后的双向有序链 表的最后一个节点连接;

如果右子树为空,对应双向有序链表的最后一个节点是根节点,右边不需要其他操作;

如果右子树不为空,对应双向有序链表的最后一个节点就是右子树转换后双向有序链表的最后一个节点,同时将根节点和右子树转换后的双向有序链表的第一个节点连 接。

参考代码如下:

    /******************************************************************************
    参数:
    pRoot: 二叉查找树根节点指针
    pFirstNode: 转换后双向有序链表的第一个节点指针
    pLastNode: 转换后双向有序链表的最后一个节点指针
    ******************************************************************************/
    void Convert(BinaryTreeNode * pRoot,
                 BinaryTreeNode * & pFirstNode, BinaryTreeNode * & pLastNode)
    {
        BinaryTreeNode *pFirstLeft, *pLastLeft, * pFirstRight, *pLastRight;
        if(pRoot == NULL)
        {
            pFirstNode = NULL;
            pLastNode = NULL;
            return;
        }  

        if(pRoot->m_pLeft == NULL)
        {
            // 如果左子树为空,对应双向有序链表的第一个节点是根节点
            pFirstNode = pRoot;
        }
        else
        {
            Convert(pRoot->m_pLeft, pFirstLeft, pLastLeft);
            // 二叉查找树对应双向有序链表的第一个节点就是左子树转换后双向有序链表的第一个节点
            pFirstNode = pFirstLeft;
            // 将根节点和左子树转换后的双向有序链表的最后一个节点连接
            pRoot->m_pLeft = pLastLeft;
            pLastLeft->m_pRight = pRoot;
        }  

        if(pRoot->m_pRight == NULL)
        {
            // 对应双向有序链表的最后一个节点是根节点
            pLastNode = pRoot;
        }
        else
        {
            Convert(pRoot->m_pRight, pFirstRight, pLastRight);
            // 对应双向有序链表的最后一个节点就是右子树转换后双向有序链表的最后一个节点
            pLastNode = pLastRight;
            // 将根节点和右子树转换后的双向有序链表的第一个节点连接
            pRoot->m_pRight = pFirstRight;
            pFirstRight->m_pLeft = pRoot;
        }  

        return;
    }  

6. 求二叉树第K层的节点个数

递归解法:

(1)如果二叉树为空或者k<1返回0

(2)如果二叉树不为空并且k==1,返回1

(3)如果二叉树不为空且k>1,返回左子树中k-1层的节点个数与右子树k-1层节点个数之和

参考代码如下:

int GetNodeNumKthLevel(BinaryTreeNode * pRoot, int k)
{
    if(pRoot == NULL || k < 1)
        return 0;
    if(k == 1)
        return 1;
    int numLeft = GetNodeNumKthLevel(pRoot->m_pLeft, k-1); // 左子树中k-1层的节点个数
    int numRight = GetNodeNumKthLevel(pRoot->m_pRight, k-1); // 右子树中k-1层的节点个数
    return (numLeft + numRight);
} 

7. 求二叉树中叶子节点的个数

递归解法:

(1)如果二叉树为空,返回0

(2)如果二叉树不为空且左右子树为空,返回1

(3)如果二叉树不为空,且左右子树不同时为空,返回左子树中叶子节点个数加上右子树中叶子节点个数

参考代码如下:

    int GetLeafNodeNum(BinaryTreeNode * pRoot)
    {
        if(pRoot == NULL)
            return 0;
        if(pRoot->m_pLeft == NULL && pRoot->m_pRight == NULL)
            return 1;
        int numLeft = GetLeafNodeNum(pRoot->m_pLeft); // 左子树中叶节点的个数
        int numRight = GetLeafNodeNum(pRoot->m_pRight); // 右子树中叶节点的个数
        return (numLeft + numRight);
    }  

8. 判断两棵二叉树是否结构相同

不考虑数据内容。结构相同意味着对应的左子树和对应的右子树都结构相同。

递归解法:

(1)如果两棵二叉树都为空,返回真

(2)如果两棵二叉树一棵为空,另一棵不为空,返回假

(3)如果两棵二叉树都不为空,如果对应的左子树和右子树都同构返回真,其他返回假

参考代码如下:

bool StructureCmp(BinaryTreeNode * pRoot1, BinaryTreeNode * pRoot2)
{
    if(pRoot1 == NULL && pRoot2 == NULL) // 都为空,返回真
        return true;
    else if(pRoot1 == NULL || pRoot2 == NULL) // 有一个为空,一个不为空,返回假
        return false;
    bool resultLeft = StructureCmp(pRoot1->m_pLeft, pRoot2->m_pLeft); // 比较对应左子树
    bool resultRight = StructureCmp(pRoot1->m_pRight, pRoot2->m_pRight); // 比较对应右子树
    return (resultLeft && resultRight);
} 

9. 判断二叉树是不是平衡二叉树

递归解法:

(1)如果二叉树为空,返回真

(2)如果二叉树不为空,如果左子树和右子树都是AVL树并且左子树和右子树高度相差不大于1,返回真,其他返回假

参考代码:

bool IsAVL(BinaryTreeNode * pRoot, int & height)
{
    if(pRoot == NULL) // 空树,返回真
    {
        height = 0;
        return true;
    }
    int heightLeft;
    bool resultLeft = IsAVL(pRoot->m_pLeft, heightLeft);
    int heightRight;
    bool resultRight = IsAVL(pRoot->m_pRight, heightRight);
    if(resultLeft && resultRight && abs(heightLeft - heightRight) <= 1) // 左子树和右子树都是AVL,并且高度相差不大于1,返回真
    {
        height = max(heightLeft, heightRight) + 1;
        return true;
    }
    else
    {
        height = max(heightLeft, heightRight) + 1;
        return false;
    }
} 

10. 求二叉树的镜像

递归解法:

(1)如果二叉树为空,返回空

(2)如果二叉树不为空,求左子树和右子树的镜像,然后交换左子树和右子树

参考代码如下:

BinaryTreeNode * Mirror(BinaryTreeNode * pRoot)
{
    if(pRoot == NULL) // 返回NULL
        return NULL;
    BinaryTreeNode * pLeft = Mirror(pRoot->m_pLeft); // 求左子树镜像
    BinaryTreeNode * pRight = Mirror(pRoot->m_pRight); // 求右子树镜像
        // 交换左子树和右子树
    pRoot->m_pLeft = pRight;
    pRoot->m_pRight = pLeft;
    return pRoot;
} 

11. 求二叉树中两个节点的最低公共祖先节点

递归解法:

(1)如果两个节点分别在根节点的左子树和右子树,则返回根节点

(2)如果两个节点都在左子树,则递归处理左子树;如果两个节点都在右子树,则递归处理右子树

参考代码如下:

    bool FindNode(BinaryTreeNode * pRoot, BinaryTreeNode * pNode)
    {
        if(pRoot == NULL || pNode == NULL)
            return false;  

        if(pRoot == pNode)
            return true;  

        bool found = FindNode(pRoot->m_pLeft, pNode);
        if(!found)
            found = FindNode(pRoot->m_pRight, pNode);  

        return found;
    }  

    BinaryTreeNode * GetLastCommonParent(BinaryTreeNode * pRoot,
                                         BinaryTreeNode * pNode1,
                                         BinaryTreeNode * pNode2)
    {
        if(FindNode(pRoot->m_pLeft, pNode1))
        {
            if(FindNode(pRoot->m_pRight, pNode2))
                return pRoot;
            else
                return GetLastCommonParent(pRoot->m_pLeft, pNode1, pNode2);
        }
        else
        {
            if(FindNode(pRoot->m_pLeft, pNode2))
                return pRoot;
            else
                return GetLastCommonParent(pRoot->m_pRight, pNode1, pNode2);
        }
    }  

递归解法效率很低,有很多重复的遍历,下面看一下非递归解法。

非递归解法:

先求从根节点到两个节点的路径,然后再比较对应路径的节点就行,最后一个相同的节点也就是他们在二叉树中的最低公共祖先节点

参考代码如下:

    bool GetNodePath(BinaryTreeNode * pRoot, BinaryTreeNode * pNode,
                     list<BinaryTreeNode *> & path)
    {
        if(pRoot == pNode)
        {
            path.push_back(pRoot);
            return true;
        }
        if(pRoot == NULL)
            return false;
        path.push_back(pRoot);
        bool found = false;
        found = GetNodePath(pRoot->m_pLeft, pNode, path);
        if(!found)
            found = GetNodePath(pRoot->m_pRight, pNode, path);
        if(!found)
            path.pop_back();
        return found;
    }
    BinaryTreeNode * GetLastCommonParent(BinaryTreeNode * pRoot, BinaryTreeNode * pNode1, BinaryTreeNode * pNode2)
    {
        if(pRoot == NULL || pNode1 == NULL || pNode2 == NULL)
            return NULL;
        list<BinaryTreeNode*> path1;
        bool bResult1 = GetNodePath(pRoot, pNode1, path1);
        list<BinaryTreeNode*> path2;
        bool bResult2 = GetNodePath(pRoot, pNode2, path2);
        if(!bResult1 || !bResult2)
            return NULL;
        BinaryTreeNode * pLast = NULL;
        list<BinaryTreeNode*>::const_iterator iter1 = path1.begin();
        list<BinaryTreeNode*>::const_iterator iter2 = path2.begin();
        while(iter1 != path1.end() && iter2 != path2.end())
        {
            if(*iter1 == *iter2)
                pLast = *iter1;
            else
                break;
            iter1++;
            iter2++;
        }
        return pLast;
    }  

在上述算法的基础上稍加变化即可求二叉树中任意两个节点的距离了。

12. 求二叉树中节点的最大距离

即二叉树中相距最远的两个节点之间的距离。

递归解法:

(1)如果二叉树为空,返回0,同时记录左子树和右子树的深度,都为0

(2)如果二叉树不为空,最大距离要么是左子树中的最大距离,要么是右子树中的最大距离,要么是左子树节点中到根节点的最大距离+右子树节点中到根节点的最大距离,同时记录左子树和右子树节点中到根节点的最大距离。

参考代码如下:

    int GetMaxDistance(BinaryTreeNode * pRoot, int & maxLeft, int & maxRight)
    {
        // maxLeft, 左子树中的节点距离根节点的最远距离
        // maxRight, 右子树中的节点距离根节点的最远距离
        if(pRoot == NULL)
        {
            maxLeft = 0;
            maxRight = 0;
            return 0;
        }
        int maxLL, maxLR, maxRL, maxRR;
        int maxDistLeft, maxDistRight;
        if(pRoot->m_pLeft != NULL)
        {
            maxDistLeft = GetMaxDistance(pRoot->m_pLeft, maxLL, maxLR);
            maxLeft = max(maxLL, maxLR) + 1;
        }
        else
        {
            maxDistLeft = 0;
            maxLeft = 0;
        }
        if(pRoot->m_pRight != NULL)
        {
            maxDistRight = GetMaxDistance(pRoot->m_pRight, maxRL, maxRR);
            maxRight = max(maxRL, maxRR) + 1;
        }
        else
        {
            maxDistRight = 0;
            maxRight = 0;
        }
        return max(max(maxDistLeft, maxDistRight), maxLeft+maxRight);
    }  

13. 由前序遍历序列和中序遍历序列重建二叉树

二叉树前序遍历序列中,第一个元素总是树的根节点的值。中序遍历序列中,左子树的节点的值位于根节点的值的左边,右子树的节点的值位

于根节点的值的右边。

递归解法:

(1)如果前序遍历为空或中序遍历为空或节点个数小于等于0,返回NULL。

(2)创建根节点。前序遍历的第一个数据就是根节点的数据,在中序遍历中找到根节点的位置,可分别得知左子树和右子树的前序和中序遍

历序列,重建左右子树。

  1. BinaryTreeNode * RebuildBinaryTree(int* pPreOrder, int* pInOrder, int nodeNum)
    {
        if(pPreOrder == NULL || pInOrder == NULL || nodeNum <= 0)
            return NULL;
        BinaryTreeNode * pRoot = new BinaryTreeNode;
        // 前序遍历的第一个数据就是根节点数据
        pRoot->m_nValue = pPreOrder[0];
        pRoot->m_pLeft = NULL;
        pRoot->m_pRight = NULL;
        // 查找根节点在中序遍历中的位置,中序遍历中,根节点左边为左子树,右边为右子树
        int rootPositionInOrder = -1;
        for(int i = 0; i < nodeNum; i++)
            if(pInOrder[i] == pRoot->m_nValue)
            {
                rootPositionInOrder = i;
                break;
            }
        if(rootPositionInOrder == -1)
        {
            throw std::exception("Invalid input.");
        }
        // 重建左子树
        int nodeNumLeft = rootPositionInOrder;
        int * pPreOrderLeft = pPreOrder + 1;
        int * pInOrderLeft = pInOrder;
        pRoot->m_pLeft = RebuildBinaryTree(pPreOrderLeft, pInOrderLeft, nodeNumLeft);
        // 重建右子树
        int nodeNumRight = nodeNum - nodeNumLeft - 1;
        int * pPreOrderRight = pPreOrder + 1 + nodeNumLeft;
        int * pInOrderRight = pInOrder + nodeNumLeft + 1;
        pRoot->m_pRight = RebuildBinaryTree(pPreOrderRight, pInOrderRight, nodeNumRight);
        return pRoot;
    } 

同样,有中序遍历序列和后序遍历序列,类似的方法可重建二叉树,但前序遍历序列和后序遍历序列不同恢复一棵二叉树,证明略。

14.判断二叉树是不是完全二叉树

若设二叉树的深度为h,除第 h 层外,其它各层 (1~h-1) 的结点数都达到最大个数,第 h 层所有的结点都连续集中在最左边,这就是完全

二叉树。

有如下算法,按层次(从上到下,从左到右)遍历二叉树,当遇到一个节点的左子树为空时,则该节点右子树必须为空,且后面遍历的节点左

右子树都必须为空,否则不是完全二叉树。

        bool IsCompleteBinaryTree(BinaryTreeNode * pRoot)
        {
            if(pRoot == NULL)
                return false;
            queue<BinaryTreeNode *> q;
            q.push(pRoot);
            bool mustHaveNoChild = false;
            bool result = true;
            while(!q.empty())
            {
                BinaryTreeNode * pNode = q.front();
                q.pop();
                if(mustHaveNoChild) // 已经出现了有空子树的节点了,后面出现的必须为叶节点(左右子树都为空)
                {
                    if(pNode->m_pLeft != NULL || pNode->m_pRight != NULL)
                    {
                        result = false;
                        break;
                    }
                }
                else
                {
                    if(pNode->m_pLeft != NULL && pNode->m_pRight != NULL)
                    {
                        q.push(pNode->m_pLeft);
                        q.push(pNode->m_pRight);
                    }
                    else if(pNode->m_pLeft != NULL && pNode->m_pRight == NULL)
                    {
                        mustHaveNoChild = true;
                        q.push(pNode->m_pLeft);
                    }
                    else if(pNode->m_pLeft == NULL && pNode->m_pRight != NULL)
                    {
                        result = false;
                        break;
                    }
                    else
                    {
                        mustHaveNoChild = true;
                    }
                }
            }
            return result;
        } 
时间: 2024-08-10 17:19:59

php数据结构之二叉树的相关文章

数据结构:二叉树的链式存储

数据结构:二叉树的链式存储(C语言版) 1.写在前面 二叉树同样有两种存储方式,数组和链式存储,对于数组来说,我们利用二叉树的性质然后利用下标可以方便的找到一个节点的子节点和父节点. 二叉树的性质: 1.二叉树的第i层上至多有2i-1个节点 2.深度为K的二叉树至多有2k-1个节点 3.任何一个二叉树中度数为2的节点的个数必度数为0的节点数目少1. 说明:度数为0,为叶子节点. 4.具有n个节点的完全二叉树的深度为|_Log2N_|+1 5.若完全二叉树中的某节点编号为i,则若有左孩子编号为2i

数据结构之二叉树查找

数据结构之--二叉树查找 定义:它是一棵树,或者具有以下性质的树.  若它的左子树不空,则左子树上所有节点的值均小于它的根节点的值: 若它的右子树不空,则右子树上所有节点的值均大于它的根节点的值:  它的左.右子树也分别为二叉排序树: 图解: ?        ?    ?    ?    ?    ?? #include<stdio.h> #include<stdlib.h> typedef int Status; #define TRUE 1 #define FALSE 0 t

数据结构之二叉树遍历

二叉树的 二叉树节点的描述 public class BiTNode { char data; BiTNode lc,rc; } 下面我们分别用递归和非递归实现前.中.后序遍历,以及使用了两种方法来进行层次遍历二叉树,一种方法就是使用STL中的queue,另外一种方法就是定义了一个数组队列,分别使用了front和rear两个数组的下标来表示入队与出队. 1.前序遍历 未完待续... 数据结构之二叉树遍历,布布扣,bubuko.com

【算法与数据结构】二叉树 中序线索

中序线索二叉树 /************************************************************************ 线索二叉树 二叉树的节点有五部分构造 ----------------------------------------- | lChild | lTag | value | rTag | rChild | ----------------------------------------- lChild = (lTag == 0 ? 左

【算法与数据结构】二叉树的 中序 遍历

前一篇写了二叉树的先序遍历,本篇记录一下二叉树的中序遍历,主要是非递归形式的中序遍历. 由于距离上篇有好几天了,所以这里把二叉树的创建和存储结构也重复的写了一遍. 二叉树如下 二叉树的存储方式依然是二叉链表方式,其结构如下 typedef struct _tagBinTree { unsigned char value; struct _tagBinTree* left; struct _tagBinTree* right; }BinTree, *PBinTree; 先序递归形式的创建二叉树代码

数据结构之二叉树的遍历汇总

声明:小弟写博客不久,主要是边上班边学习边写博客,如果错误,望各位包涵并指导. 二叉树是一种常用的非线性数据结构,二叉树是由一个根节点和称为根的左.右子树的两颗互不相交的二叉树构成.二叉树具有一些特殊的性质,如第i层上最多有2^(i-1)个结点.二叉树的链式存储结构如下: typedef struct BTNode { char data; //字符型数据; struct BTNode* lChild,*rChild; //左右子结点的指针; }BTNode,*BiTree; data为二叉树中

采用栈数据结构的二叉树遍历

[前言]树的遍历,根据访问自身和其子节点之间的顺序关系,分为前序,后序遍历.对于二叉树,每个节点至多有两个子节点(特别的称为左,右子节点),又有中序遍历.由于树自身具有的递归性,这些遍历函数使用递归函数很容易实现,代码也非常简洁.借助于数据结构中的栈,可以把树遍历的递归函数改写为非递归函数. 在这里我思考的问题是,很显然,循环可以改写为递归函数.递归函数是否借助栈这种数据结构改写为循环呢.因为函数调用中,call procedure stack 中存储了流程的 context,调用和返回相当于根

python环境下使用mysql数据及数据结构和二叉树算法(图)

python环境下使用mysql数据及数据结构和二叉树算法(图):1 python环境下使用mysql2使用的是 pymysql库3 开始-->创建connection-->获取cursor-->操作-->关闭cursor->关闭connection->结束45 代码框架6 import pymysql.cursors7 ###连接数据库8 connection = pymysql.connect(host='127.0.0.1',port=3306,user='roo

数据结构-二叉树笔记

看完<数据结构与算法分析>(c描述)后对二叉树的一点总结 树的节点声明: 1 typedef int ElementType; 2 typedef struct TreeNode* Position; 3 typedef Position BiSearchTree; 4 5 struct TreeNode 6 { 7 ElementType Element; 8 Position Left,Right; 9 10 }; 二叉查找树的定义如下: 1.二叉查找树首先是一棵二叉树: 2.二叉查找树除

基本数据结构之二叉树

C语言实现二叉树的遍历 二叉树结点的定义 /* 先序,中序,后序的遍历时间复杂度为O(n),每个结点只访问一次. 层序的时间复杂度最差为O(n^2),当二叉树基本平衡时,时间复杂度为O(n) n为结点个数 */ typedef int tree_node_element; /** * @author 韦轩 * @time 2015/07/11 * @brief 二叉树的结点数据结构 * */ typedef struct binary_tree_node { binary_tree_node*