非递归方式实现二叉树四种遍历
admin
2024-01-20 21:18:42
0

问题描述 

【问题描述】

非递归方式实现二叉树的先序遍历、中序遍历、后序遍历和层序遍历。

提示:(1)利用先序建立二叉树序列;(2)求四种遍历结果。

【输入形式】

(1)先序建立二叉树序列

(2)非递归方式遍历

【输出形式】

四种遍历结果

【样例输入】

ABD#G###CE##FH###

【样例输出】

PreOrder:ABDGCEFH

InOrder:DGBAECHF

PostOrder:GDBEHFCA

CcOrder:ABCDEFGH

【评分标准】:四种遍历必须以非递归方式实现。

程序实现 

#include
#include
#define MAX 20

typedef struct BitNode
{
    char data;
    struct BitNode *lchild,*rchild;
}BitNode,*BiTree;

typedef struct SqQueue
{
    int data[MAX];
    int rear,front;
}SqQueue;

void Creat (BiTree *t)
{
    char s;
    BiTree p;
    scanf("%c",&s);
    if(s=='#')
    {
        *t=0;
        return;
    }
    p=(BiTree)malloc(sizeof(BitNode));
    p->data=s;
    *t=p;
    Creat(&p->lchild);
    Creat(&p->rchild);
}

void Pre_n(BiTree p)
{
    BiTree stack[MAX],q;
    int top=0,i;
    for(i=0;i     stack[i]=0;
    q=p;
    while(q)
    {
        printf("%c",q->data);
        if(q->rchild)
            stack[top++]=q->rchild;
        if(q->lchild)
            q=q->lchild;
        else if(top>0)
                q=stack[--top];
             else
                 q=0;
    }
}

void In_n(BiTree t)
{
    BiTree stack[MAX],p;
    int top=0;
    p=t;
   if(p)
   {
       while(p||top>0)
       {
           while(p)
           {
               stack[top++]=p;
               p=p->lchild;
           }
           if(top>0)
           {
               p=stack[--top];
               printf("%c",p->data);
               p=p->rchild;
           }
       }
   }
}

void Post_n(BiTree t)
{
    BiTree stack[MAX],p;
    int i,top=0,flag[MAX];
    for(i=0;i     {
        stack[i]=0;
        flag[i]=0;
    }
    if(!t)
        return;
    p=t;
    while(p||top>0)
    {
        if(p)
        {
            stack[top]=p;
            flag[top++]=1;
            p=p->lchild;
        }
        else
        {
            p=stack[top-1];
            if(flag[top-1]==1)
            {
                flag[top-1]=2;
                p=p->rchild;
            }
            else
            {
                printf("%c",p->data);
                top--;
                p=0;
            }
        }
    }
}

void CcOrder (BiTree t)
{
    BiTree p;
    SqQueue qlist,*q;
    q=&qlist;
    q->rear=0;
    q->front=0;
    p=t;
    if(p)
    {
        printf("%c",p->data);
        q->data[q->rear]=p;
        q->rear=(q->rear+1)%MAX;
        while(q->front!=q->rear)
        {
            p=q->data[q->front];
            q->front=(q->front+1)%MAX;
            if(p->lchild)
            {
                printf("%c",p->lchild->data);
                q->data[q->rear]=p->lchild;
                q->rear=(q->rear+1)%MAX;
            }
            if(p->rchild)
                {
                    printf("%c",p->rchild->data);
                    q->data[q->rear]=p->rchild;
                    q->rear=(q->rear+1)%MAX;
                }
        }
    }
}
int main()
{
    BiTree t=0;
    Creat(&t);
    if(!t)
        printf("");
    else
    {
        printf("PreOrder:");
        Pre_n(t);
        printf("\n");
        printf("InOrder:");
        In_n(t);
        printf("\n");
        printf("PostOrder:");
        Post_n(t);
        printf("\n");
        printf("CcOrder:");
        CcOrder(t);
        printf("\n");
        return 0;
    }

相关内容

热门资讯

安卓系统gps定位功能,技术原... 深入解析安卓系统GPS定位功能:技术原理与应用场景随着智能手机的普及,GPS定位功能已经成为现代生活...
49安卓版本虚拟系统,功能、优... 深入解析49安卓版本虚拟系统:功能、优势与使用指南随着智能手机和平板电脑的普及,用户对于系统性能和功...
安卓系统发行版,多样性与定制化... 深入解析安卓系统发行版:多样性与定制化的世界安卓系统,作为全球最受欢迎的移动操作系统之一,其强大的开...
安卓系统音色设置在哪,安卓系统... 安卓系统音色设置在哪?全面解析音色调整方法随着智能手机的普及,用户对手机音质的要求越来越高。安卓系统...
sony 电视 升级安卓系统,... 索尼电视升级安卓系统:操作指南与注意事项一、升级前的准备工作在开始升级之前,请确保您的索尼电视满足以...
安卓桌面系统的电脑,跨界融合的... 安卓桌面系统电脑:跨界融合的新趋势一、安卓桌面系统的起源与发展安卓桌面系统起源于Android操作系...
安卓系统 运动数据导出,轻松掌... 安卓系统运动数据导出攻略:轻松掌握你的健康数据一、了解运动数据导出的重要性运动数据导出对于运动爱好者...
安卓手机系统哪个耐用,安卓手机... 安卓手机系统哪个耐用?深度解析各大系统优缺点随着智能手机市场的蓬勃发展,安卓系统凭借其开放性和丰富的...
云os系统越狱安卓系统版本,探... 云OS系统越狱安卓系统版本:探索与挑战随着智能手机市场的不断发展,用户对于系统个性化的需求日益增长。...
安卓系统多开分身软件 安卓系统多开分身软件:轻松管理多个账户 提升手机使用体验随着移动互联网的快速发展,越来越多的用...
安卓系统曝重大漏洞,安卓系统曝... 安卓系统曝重大漏洞,数百万用户面临安全风险随着智能手机的普及,安卓系统作为全球最流行的移动操作系统,...
恒易贷安卓系统,便捷贷款,轻松... 恒易贷安卓版:便捷贷款,轻松解决资金难题随着移动互联网的快速发展,越来越多的金融服务开始走向线上,恒...
基于安卓的nas系统,打造个人... 基于安卓的NAS系统:打造个人私有云存储解决方案一、什么是基于安卓的NAS系统?基于安卓的NAS系统...
安卓系统gps打不开,安卓系统... 安卓系统GPS打不开?解决方法大揭秘!随着智能手机的普及,GPS定位功能已经成为我们日常生活中不可或...
安卓现在用什么系统,多样化发展... 安卓系统现状:多样化发展,AI赋能未来随着智能手机的普及,安卓系统作为全球最流行的移动操作系统,已经...
安卓健康跟踪系统代码,安卓健康... 安卓健康跟踪系统代码实现详解一、系统概述安卓健康跟踪系统主要包括以下几个模块: 数据采集模块:...
干净 刷机 安卓系统,轻松提升... 安卓系统刷机指南:轻松提升手机性能与体验随着智能手机的普及,安卓系统因其开放性和可定制性而受到广大用...
安卓系统 如何查看sd,安卓系... 安卓系统查看SD卡的方法详解随着智能手机的普及,SD卡作为外部存储设备,在安卓系统中扮演着重要的角色...
安卓待机系统桌面耗电,安卓待机... 安卓待机系统桌面耗电原因及解决方法随着智能手机的普及,安卓系统因其开放性和丰富的应用生态而受到广大用...
安卓系统8.0强刷,轻松升级,... 安卓系统8.0强刷指南:轻松升级,享受全新体验一、了解安卓系统8.0安卓8.0(代号Oreo)是谷歌...