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

二叉树的遍历
先序递归遍历

void PreOrder(BTREE BT)
{
    if(!isEmpty(BT))
    {
        visit(Data(BT));
        PreOrder(lchild(BT));
        PreOrder(rchild(BT));
    }
}


中序递归遍历

void InOrder(BTREE BT)
{
    if(!isEmpty(BT))
    {
        InOrder(lchild(BT));
        visit(Data(BT));
        InOrder(rchild(BT));
    }
}


后序递归遍历

void PostOrder(BTREE BT)
{
    if(!isEmpty(BT))
    {
        PostOrder(lchild(BT));
        PostOrder(rchild(BT));
        visit(Data(BT));
    }
}


层序遍历,会用到队列
基本思想:按层次顺序遍历二叉树的原则是先被访问的左,右儿子结点先被访问,
因此,在遍历过程中需利用具有先进先出特性的队列结构。
实现步骤:
1.队列Q初始化;
2.如果二叉树非空,将根指针入队;
3.循环直到队列Q为空
    3.1 q=队列Q的队头元素出队;
    3.2 访问结点q的数据域
    3.3若结点q存在左孩子,则将左孩子指针入队
    3.4若结点q存在右孩子,则将右孩子指针入队。
 

void LeverOrder(BTREE root)
{
    Queue Q;
    BTREE q;
    MakeNull(Q);
    if(root == NULL) 
    {
        return ;
    }
    EnQueue(root,Q);
    while(!isEmpty(Q))
    {
        q=Front(Q);
        DeQueue(Q);
        visit(Data(q));
        if(q->lchild!=NULL) EnQueue(q->lchild,Q);
        is(q>rchild!=NULL) EnQueue(q->rchild,Q);
    }
}

先序遍历非递归算法
核心步骤:
1.栈S初始化
2.循环直到root为空且栈S为空
    2.1当root不空时循环
        2.1.1输出root->data;
        2.1.2将指针root的值保存到栈中
        2.1.3继续遍历root的左子树
    2.2如果栈S不空,则:
        2.2.1将栈顶元素弹出至root;
        2.2.2准备遍历root的右子树
 

void PreOrder(BTREE root)
{
    stack S;
    MakeNull(S);//初始化栈
    while(!isEmpty(root) || !S.isEmpty())
    {
        while(root!=NULL)
        {
            visit(Data(root));
            push(root,S);
            root=root->lchild;
        }
        while(!S.isEmpty)
        {
            root=S.Top();
            Pop(S);
            root=root->rchild;
        }
        
    return;
}

中序遍历非递归算法
核心步骤:
1.栈S初始化;
2.循环直到root为空且栈S为空
    2.1当root不空时循环
        2.1.1将指针root的值保存到栈中;
        2.1.2继续遍历root的左子树
    2.2如果栈S不空,则:
        2.2.1 将栈顶元素弹出至root;
        2.2.2输出root->data;
        2.2.3准备遍历root的右子树
 

void InOrder(BTREE root)
{
    stack S;
    MakeNull(S); //递归工作栈
    while(root!=NULL || !isEmpty(S))
    {
        while(root!=NULL)
        {
            push(root,S);
            root=root->lchild;
        }
        while(!isEmpty(S))
        {
            root=top(S);
            pop(S);
            visit(Data(root));
            root=root->rchild;
        }
    }
}

后序遍历非递归算法
核心步骤:
1.栈S初始化;
2.循环直到root为空且栈S为空
    2.1当root不空时循环
        2.1.1将root连同标志flag=1入栈;
        2.1.2继续遍历root的左子树;
    2.2当栈s非空且栈顶元素的标志为2时,出栈并输出栈顶结点。
    2.3若栈非空,将栈顶元素的标志改为2,准备遍历栈顶点的右子树。
 

void PostOrder(BTREE root)
{
    stack S;
    MakeNull(S);
    while(root!=NULL || !isEmpty(S))
    {
        while(root!=NULL)
        {
            S.top++;
            S[S.top].ptr=root;
            S[S.top].flag=1;
            root=root->lchild;
        }
        while(!isEmpty(S) && S.[S.top].flag==2)
        {
            count<<S.[S.top].ptr->data;
            pop(S);
        }
        while(!isEmpty(S))
        {
            S[S.top].flag=2;
            root=S[S.top].ptr->rchild;
        }
    }
    return;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
1. 遍历二叉树 遍历二叉树是指按照一定的方式访问二叉树中的每个节点。常见的遍历方式有前序遍历、中序遍历和后序遍历。 - 前序遍历:先访问根节点,再遍历左子树,最后遍历右子树。 - 中序遍历:先遍历左子树,再访问根节点,最后遍历右子树。 - 后序遍历:先遍历左子树,再遍历右子树,最后访问根节点。 遍历二叉树算法一般采用递归的方式实现。 2. 二叉树的查找 二叉树的查找是指在二叉树中查找一个特定的节点。查找的算法可以采用递归或非递归的方式实现。 - 递归查找:从根节点开始,如果目标节点的值小于当前节点的值,则继续在左子树中查找;如果目标节点的值大于当前节点的值,则继续在右子树中查找;如果目标节点的值等于当前节点的值,则返回当前节点。 - 非递归查找:从根节点开始,依次比较目标节点的值和当前节点的值,如果目标节点的值小于当前节点的值,则继续在左子树中查找;如果目标节点的值大于当前节点的值,则继续在右子树中查找;如果目标节点的值等于当前节点的值,则返回当前节点。 3. 插入节点 向二叉树中插入一个节点,需要找到该节点的插入位置,并将其插入到相应的位置。插入节点的算法可以采用递归或非递归的方式实现。 - 递归插入:从根节点开始,如果目标节点的值小于当前节点的值,则继续在左子树中插入;如果目标节点的值大于当前节点的值,则继续在右子树中插入;如果目标节点的值等于当前节点的值,则返回。 - 非递归插入:从根节点开始,依次比较目标节点的值和当前节点的值,如果目标节点的值小于当前节点的值,则继续在左子树中插入;如果目标节点的值大于当前节点的值,则继续在右子树中插入;如果目标节点的值等于当前节点的值,则返回。 4. 删除节点 从二叉树中删除一个节点,需要找到该节点的位置,并将其删除。删除节点的算法可以采用递归或非递归的方式实现。 - 递归删除:从根节点开始,如果目标节点的值小于当前节点的值,则继续在左子树中删除;如果目标节点的值大于当前节点的值,则继续在右子树中删除;如果目标节点的值等于当前节点的值,则根据节点的类型进行删除操作。 - 非递归删除:从根节点开始,依次比较目标节点的值和当前节点的值,如果目标节点的值小于当前节点的值,则继续在左子树中删除;如果目标节点的值大于当前节点的值,则继续在右子树中删除;如果目标节点的值等于当前节点的值,则根据节点的类型进行删除操作。 5. 求二叉树的深度 求二叉树的深度是指求二叉树中从根节点到最远叶子节点的路径上的节点数。求二叉树的深度的算法可以采用递归或非递归的方式实现。 - 递归求深度:从根节点开始,如果二叉树为空,则深度为0,否则深度等于左子树和右子树深度的最大值加1。 - 非递归求深度:采用层次遍历的方式求深度,记录每一层的节点数,直到遍历到最后一层,深度即为层数。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值