首页 > 其他分享 >TreeAPI 递归和非递归遍历

TreeAPI 递归和非递归遍历

时间:2023-10-09 21:45:04浏览次数:31  
标签:遍历 return 递归 printf rchild data Stack TreeAPI

只包含递归和非递归遍历

#include <stdio.h>
#include <stdlib.h>

#define MaxSize 20

typedef struct node{
    int data;
    struct node *lchild,*rchild;
}TreeNode,*Tree;

typedef TreeNode* Elem;            //方便修改栈中元素类型 

typedef struct{
    Elem data[MaxSize];
    int top;
}Stack;

void InitStack(Stack &S)        //初始化栈 
{
    S.top=-1;
}

bool isEmpty(Stack S)            //判空 
{
    if(S.top==-1)
        return true;
    else
        return false;
}

bool isFull(Stack S)        //判满 
{
    if(S.top==MaxSize-1)
        return true;
    else
        return false;
}

bool Push(Stack &S,Elem x)        //压栈 
{
    if(isFull(S))
        return false;
    S.data[++S.top]=x;
    return true;    
}

bool Pop(Stack &S,Elem &x)        //弹栈 
{
    if(isEmpty(S))
        return false;
    x=S.data[S.top--];
    return true;
}

bool GetTop(Stack S,Elem &x)    //获取栈顶元素 
{
    if(isEmpty(S))
        return false;
    x=S.data[S.top];
    return true;
}

void CreateTree(Tree &T)        //先序创建二叉树,中序后序创建和递归遍历一样,只修改位置 
{
    int x;
    scanf("%d",&x);
    if(x==-1)
    {
        T=NULL;
        return;    
    }
    else
    {
        T=(TreeNode*)malloc(sizeof(TreeNode));
        T->data=x;
        printf("输入%d的左结点:",x);
        CreateTree(T->lchild);
        printf("输入%d的右结点:",x);
        CreateTree(T->rchild);
    }
}
 
void PreOrder(Tree T)        //先序遍历 
{
    if(T!=NULL)
    {
        printf("%d  ",T->data);
        PreOrder(T->lchild);
        PreOrder(T->rchild);
    }
}

void MidOrder(Tree T)        //中序遍历 
{
    if(T!=NULL)
    {
        MidOrder(T->lchild);
        printf("%d  ",T->data);
        MidOrder(T->rchild);
    }
}

void LatOrder(Tree T)        //后序遍历 
{
    if(T!=NULL)
    {
        LatOrder(T->lchild);
        LatOrder(T->rchild);
        printf("%d  ",T->data);
    }
}

void PreOrderByStack(Tree T)    //先序非递归遍历 
{
    Stack S;
    InitStack(S);
    TreeNode *p=T;
    while(p || !isEmpty(S))
    {
        if(p)
        {
            printf("%d  ",p->data);
            Push(S,p);
            p=p->lchild;
        }
        else
        {
            Pop(S,p);
            p=p->rchild;
        }
    }
}

void MidOrderByStack(Tree T)        //中序非递归遍历 
{
    Stack S;
    InitStack(S);
    TreeNode *p=T;
    while(p || !isEmpty(S))
    {
        if(p)
        {
            Push(S,p);
            p=p->lchild;
        }
        else
        {
            Pop(S,p);
            printf("%d  ",p->data);
            p=p->rchild;
        }
    }
}

void LatOrderByStack(Tree T)        //后序非递归遍历 
{
    Stack S;
    InitStack(S);
    TreeNode *p=T;
    TreeNode *r=NULL;
    while(p || !isEmpty(S))
    {
        if(p)
        {
            Push(S,p);
            p=p->lchild;
        }
        else
        {
            GetTop(S,p);
            if(p->rchild&&p->rchild!=r)
            {
                p=p->rchild;
            }
            else
            {
                Pop(S,p);
                printf("%d  ",p->data);
                r=p;
                p=NULL;
            }
        }
    }
}

int main()
{
    Tree T;
    CreateTree(T);
    PreOrder(T);
    printf("\n");
    PreOrderByStack(T);
    printf("\n");
    MidOrder(T);
    printf("\n");
    MidOrderByStack(T);
    printf("\n");
    LatOrder(T);
    printf("\n");
    LatOrderByStack(T);
     
    return 0;    
} 

 

标签:遍历,return,递归,printf,rchild,data,Stack,TreeAPI
From: https://www.cnblogs.com/simpleset/p/17753240.html

相关文章

  • 在JavaScript中遍历数组的循环(对于每个)
    内容来自DOChttps://q.houxu6.top/?s=在JavaScript中遍历数组的循环(对于每个)我可以使用JavaScript遍历数组中的所有条目吗?TL;DR你最好选择通常的方法是:使用for-of循环(ES2015+只支持;规范|MDN)-简单且适用于async。for(constelementoftheArray){//.......
  • 143-3 二叉树后序非递归遍历
    二叉树的后序非递归遍历使用辅助栈 r指针的作用是判断该结点是否遍历过#include<stdio.h>#include<stdlib.h>#defineMaxSize20typedefstructnode{intdata;structnode*lchild,*rchild;}TreeNode,*Tree;typedefTreeNode*Elem;typedefstruct{......
  • Java Hutool递归解压文件
    importcn.hutool.core.io.FileUtil;importcn.hutool.core.util.ZipUtil;importjava.io.File;importjava.nio.charset.Charset;publicclassRecursiveUnzip{finalstaticFiledestDir=newFile("D:\\python\\newProject\\excel");pub......
  • vue中的循环遍历对象、数组和字符串
    vue循环遍历对象、数组和字符串1.循环遍历对象1.1vue在html里面循环遍历对象v-for="(val,key,i)indimItemMap":key="key" val-每一项key-key值i-第几个<el-table-columnprop="score"label="评分":show-overflow-tooltip="true"ali......
  • jquery之each遍历
    jQuery的each和原生的JavaScript方法forEach原生的JavaScript方法forEach是EcmaScript5提供的不兼容IE8jQuery的each由jQuery这个第三方库提供jQuery2以下的版本是兼容IE8的它的each方法主要用来遍历jQuery实例对象(伪数组)同时它也可以作为......
  • python 递归遍历目录筛选特定文件名的文件
    #!/usr/bin/pythonimportosimportsyslist=[]folder_path="/root"defsearch_files(folder_path):search_string="测试"forroot,dirs,filesinos.walk(folder_path):fornameinfiles:ifsearch_strin......
  • jmeter 两个"csv数据文件设置"遍历数据,实现多用户购买多个商品
    目标使用jmeter构造基础数据,需要实现多个用户购买多个商品的场景。 数据准备1号数据txt文件,包含token和userId,用于用户登录(有10个用户的登录信息);2号数据txt文件,包含goodsId,用户购买商品(有6个商品的Id); jmeter设置1.添加--配置元件--“CSV数据文件设置“用于读取token和u......
  • 递归分治法在快速排序中的应用 java以界面的方式实现
    递归分治法在快速排序中的应用 分治法的基本思想§分治法的基本思想是将一个规模为n的问题分解为k个规模较小的子问题,这些子问题互相独立且与原问题相同。 k个子问题分别求解。如果子问题的规模仍然不够小,则再划分为k个子问题,如此递归的进行下去,直到问题规模足够小,很容易求......
  • 递归解析Json,实现生成可视化Tree+快速获取JsonPath
    内部平台的一个小功能点的实现过程,分享给大家:递归解析Json,可以实现生成可视化Tree+快速获取JsonPath。步骤:1.利用JsonPath读取根,获取JsonObject2.递归层次遍历JsonObjec,保存结点信息3.利用zTree展示结点为可视化树,点击对应树的结点即可获取对应结点的JsonPath1.利用JsonPath......
  • sqlserver递归排序
    主要介绍了sqlserver递归排序相关的知识,希望对你有一定的参考价值。此算法不支持无限递归,只支持指定最大层级,实际应用中,一般不会超过5级,sqlserver最大只支持100级。递归层级LevelOrder序号,每层级最大序号sequences,子级序号=父级序号+父级序号/最大序号即LevelOrder=p.LevelO......