数据结构专题 | 先序非递归遍历二叉树
admin
2024-01-20 19:29:58
0

先序非递归遍历二叉树,主要是利用了栈的先进后出原理,用一个栈即可实现该算法,下面我们一起来看一下如何来实现吧

目录

先序建立二叉树 

先序递归遍历二叉树 

先序非递归遍历二叉树 


 

先序建立二叉树 

在进行先序非递归遍历之前,我们需要先建立一个二叉树,这里采用先序的方法建立二叉树

void Create(BiTree *t){
    BiTree q;    //树结点
    char s;       //输入的值
    scanf("%c",&s);
    getchar();
    if(s=='#'){       //当建立时某个树没有左孩子或右孩子时,我们输入一个#
        *t=NULL;   
        return;
    }
    q=(BiTree)malloc(sizeof(BiTree));    //分配内存
    q->data=s;
    *t=q;                               //根结点
    Create(&q->lchild);        //先序建立左子树
    Create(&q->rchild);        //先序建立右子树

先序递归遍历二叉树 

在建立完二叉树后,我们先来看看递归的算法是如何实现的 

void xianxu(BiTree t){
    if(!t) return;                     //当树节点为空时,返回
    printf("%c",t->data);       //打印跟结点
    xianxu(t->lchild);            //先序遍历左子树
    xianxu(t->rchild);            //先序遍历右子树

先序非递归遍历二叉树 

下面我们来看看如何非递归对二叉树进行遍历 

void fxianxu(BiTree t){
    BiTree stack[100],p;     //我们需要一个保存树结点的栈
    int top=0;     //栈顶指针
    for(int i=0;i<100;i++){
        stack[i]=0;      //初始化栈
    }
    p=t;           //根结点
    while(p){
        printf("%c",p->data);    //打印根结点
        if(p->rchild){                //先从右边开始,如果右子树不为空
            stack[top++]=p->rchild;      //右子树入栈
        }
        if(p->lchild){               //再看左子树,如果左子树非空
            p=p->lchild;           //继续遍历下一个左子树
        }else if(top>0){          //如果左子树为空但是栈不为空
            p=stack[--top];      //此时栈顶是当前树的右子树,将右子树出栈
        }else{                        //当左子树为空,且栈中没有元素时,遍历结束
            p=0;
        }
    }

以上代码理解起来有点抽象,我们举个例子来说明一下:

假设现在我们输入了AB##C##,这是棵最简单的二叉树,A是根结点,B是A的左子树,C是A的右子树,我们用非递归方法对其进行遍历,先看A的右子树,发现它有右子树,右子树是C,C入栈,再看A的左子树,发现它有左子树,左子树为B,我们令B为新的树结点,第一次循环结束,开始第二次循环,我们先看右子树,发现B没有右子树,不做任何操作,再看B的左子树,发现B也没有左子树,但是当前栈中有元素C,我们出栈,并令C为新的树结点,第二次循环结束,执行第三次循环,我们还是先看C的右子树,发现C没有右子树,不做任何操作,再看C的左子树,发现左子树为空,并且当前栈中没有元素,我们令新的树结点为空,即可跳出循环

我们最后来总结一下如何对二叉树进行先序非递归的遍历:

第一步,打印根结点

第二步,先看树结点的右子树,存在,入栈

第三步,再看树结点的左子树,存在,令其为新的树结点,不存在看该树结点右子树是否存在(就是看栈中是否有元素),存在右子树就让右子树为新的树结点继续循环,当某个树结点既没有左子树也没有右子树时结束循环 

相关内容

热门资讯

麒麟os系统安卓开发,国产操作... 你知道吗?最近手机圈里可是炸开了锅,因为华为家的麒麟OS系统要大显身手了!这可不是闹着玩的,咱们得好...
橙子投屏安卓系统,安卓系统下的... 你有没有想过,家里的电视屏幕那么大,却只能用它来看个新闻或者电视剧?现在,有了橙子投屏安卓系统,你就...
刷安卓苹果双系统,实现双系统体... 哇塞,你有没有想过,你的安卓手机也能变身成为苹果手机呢?没错,就是那种流畅的iOS系统,让你在手机上...
安卓原生系统隐藏app,安卓原... 手机里藏着的小秘密,你有没有想过怎么让它们消失得无影无踪呢?今天,就让我来带你一起探索安卓原生系统隐...
通用的安卓电视系统,体验升级 亲爱的电视迷们,你是否曾为家里的电视系统烦恼过?是不是觉得每次换台都要翻遍遥控器,操作起来像是在玩迷...
安卓系统安装u盘,轻松打造便携... 你有没有想过,把安卓系统装进U盘里,随时随地都能用呢?想象你拿着一个U盘,走到哪儿用到哪儿,是不是很...
安卓系统手绘教程图解,轻松绘制... 你有没有想过,用手机也能画出美美的手绘头像呢?没错,就是那个你每天不离手的安卓手机!今天,我就要带你...
手机wp系统刷安卓,刷机教程与... 你有没有想过,你的WP手机其实也可以变身成为安卓小精灵呢?没错,就是那个应用丰富、功能强大的安卓系统...
真我安卓最新系统,探索无限可能... 亲爱的手机控们,你们有没有发现,手机系统就像是我们生活中的小秘密,时不时地给我们带来惊喜?今天,就让...
安卓仿mac系统手机,探索安卓... 哇塞,你有没有想过,如果你的安卓手机能拥有Mac系统的风采呢?想象那会是怎样一番景象?今天,就让我带...
手机虚拟系统安卓5.1,揭秘手... 你有没有想过,你的手机里其实还隐藏着一个神秘的虚拟世界?没错,就是那个你可能从未深入探索过的安卓5....
vivonex3安卓系统,体验... 你有没有想过,一部手机的操作系统就像它的灵魂,决定了它的性格和才华。今天,咱们就来聊聊vivo NE...
安卓系统降低白点值,提升视觉体... 手机屏幕上的白点是不是让你觉得眼睛都累了呢?别急,今天就来教你怎么轻松降低安卓系统的白点值,让你的屏...
系统安装app安卓下载,下载与... 亲爱的手机控们,是不是又到了为手机新添几款心仪APP的时候了呢?别急,今天就来给你详细讲解如何在你的...
安卓电脑平板双系统,探索无限可... 你有没有想过,一台平板电脑,既能让你畅游安卓的海洋,又能让你在Windows的世界里办公如鱼得水?这...
安卓系统不能更新了吗,安卓系统... 最近是不是有不少小伙伴发现,自己的安卓手机突然不能更新系统了?别急,别急,让我来给你揭秘这个谜团!安...
安卓系统游戏试玩软件,热门平台... 探索安卓系统游戏试玩软件的宝藏世界 亲爱的安卓手机用户们,你是否曾在闲暇之余,想要通过玩游戏来赚取一...
手机鸿蒙系统退回安卓,详细步骤... 亲爱的手机控们,你们有没有遇到过这种情况:手机升级了鸿蒙系统,结果发现用起来有点水土不服,心里那个痒...
欧擎恢复安卓系统,全面解析与操... 手机系统出问题了?别慌,让我来给你支个招!今天,咱们就来聊聊怎么用欧擎恢复安卓系统,让你的手机重获新...
安卓系统图标颜色修改,方法与技... 哇哦,你有没有想过,你的手机里那些小小的图标,其实也可以变得五彩斑斓,充满个性呢?没错,就是安卓系统...