数据结构树基本操作

本章内容:树的结构定义、递归的三种遍历、非递归的三种遍历、层次遍历、求深度、求特定结点以及测试的主函数。

#include <stdio.h>
#include <stdlib.h>
#define maxsize 50
//二叉树的链式存储
typedef struct BTNode
{
    //树结点存储的类型可以更换,常用int、double、char等
    int data;
    BTNode *lchild;
    BTNode *rchild;
}BTNode,*Tree;
//访问改结点数值
void visit(Tree Q)
{
    printf("%d\n",Q->data);
}
//先序遍历
void preorder(Tree Q)
{
    if(Q!=NULL)
    {
        visit(Q);
        preorder(Q->lchild);
        preorder(Q->rchild);
    }
}
//中序遍历
void midorder(Tree Q)
{
    if(Q!=NULL)
    {
        midorder(Q->lchild);
        visit(Q);
        midorder(Q->rchild);
    }
}
//后序遍历
void postorder(Tree Q)
{
    if(Q!=NULL)
    {
        postorder(Q->lchild);
        postorder(Q->rchild);
        visit(Q);
    }
}
//求高度
int getDepth(Tree Q)
{
    if(Q==NULL)
        return 0;
    else
    {
        int l,r;
        l=getDepth(Q->lchild);
        r=getDepth(Q->rchild);
        return (l>r?l:r)+1;
    }
}
//查找符合key的结点,存放到w中
void search(Tree Q,Tree &w,int key)
{
    if(Q!=NULL)
    {
        if(Q->data==key)
        {
            w=Q;
        }
        else
        {
            search(Q->lchild, w, key);
            //剪枝操作
            if(w!=NULL)
                search(Q->rchild, w, key);
        }
    }
    return;
}
//层次遍历
void level(Tree Q)
{
    int front,rear;
    Tree l[maxsize];
    Tree q;
    front=rear=0;
    if(Q!=NULL)
    {
        //初始先把根结点放入
        rear=(rear+1)%maxsize;
        l[rear]=Q;
        //循环访问
        while(front!=rear)
        {
            front=(front+1)%maxsize;
            q=l[front];
            visit(q);
            if(q->lchild!=NULL)
            {
                rear=(rear+1)%maxsize;
                l[rear]=q->lchild;
            }
            if(q->rchild!=NULL)
            {
                rear=(rear+1)%maxsize;
                l[rear]=q->rchild;
            }
        }
        
    }
}
//非递归设计遍历,先
void Npreorder(Tree Q)
{
    if(Q!=NULL)
    {
        Tree Stack[maxsize];
        int top=-1;
        Tree q;
        Stack[++top]=Q;
        while(top!=-1)
        {
            q=Stack[top--];
            visit(q);
            if(q->rchild!=NULL)
               Stack[++top]=q->rchild;
            if(q->lchild!=NULL)
                Stack[++top]=q->lchild;
        }
    }
}
//非递归设计遍历,中
void Nmidorder(Tree Q)
{
    if(Q!=NULL)
    {
        Tree q;
        Tree Stack[maxsize];
        int top=-1;
        q=Q;
        while(top!=-1||q!=NULL)
        {
            //左孩子存在,则存此刻结点再往下找做孩子
            while(q!=NULL)
            {
                Stack[++top]=q;
                q=q->lchild;
            }
            if(top!=-1)
            {
                q=Stack[top--];
                visit(q);
                q=q->rchild;
            }
        }
    }
}
//非递归设计遍历,后
void Npostorder(Tree Q)
{
    if(Q!=NULL)
    {
        Tree Stack1[maxsize];
        int top1=-1;
        Tree Stack2[maxsize];
        int top2=-1;
        Tree q=NULL;
        Stack1[++top1]=Q;
        //将所有结点都放进来
        while(top1!=-1)
        {
            q=Stack1[top1--];
            Stack2[++top2]=q;
            if(q->lchild!=NULL)
                Stack1[++top1]=q->lchild;
            if(q->rchild!=NULL)
                Stack1[++top1]=q->rchild;
        }
        //输出结点
        while (top2!=-1)
        {
            q=Stack2[top2--];
            visit(q);
        }
        
    }
}
int main()
{
    //随便写一个树
    Tree head,A,B,C,D,E;
    head=(Tree)malloc(sizeof(BTNode));
    A=(Tree)malloc(sizeof(BTNode));
    B=(Tree)malloc(sizeof(BTNode));
    C=(Tree)malloc(sizeof(BTNode));
    D=(Tree)malloc(sizeof(BTNode));
    E=(Tree)malloc(sizeof(BTNode));
    head->data=0;
    A->data=1;
    B->data=2;
    C->data=3;
    D->data=4;
    E->data=5;
    head->lchild=A;
    head->rchild=B;
    A->lchild=C;
    A->rchild=D;
    B->lchild=E;
    B->rchild=NULL;
    C->lchild=D->lchild=E->lchild=C->rchild=D->rchild=E->rchild=NULL;
    //三种遍历
    //preorder(head);
    //midorder(head);
    //postorder(head);
    //获得深度
    //printf("%d",getDepth(head));
    //层次遍历
    //level(head);
    //三种非递归遍历
    //Npreorder(head);
    //Nmidorder(head);
    //Npostorder(head);
    return 0;
}

 

  • 2
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
一、实验目的: 理解二叉特别是完全二叉的性质,掌握二叉的存储结构(二叉链表);熟练掌握二叉的常用操作算法(初始化、插入结点、删除结点、遍历等);初步掌握二叉的应用。 二、实验内容: 要求采用二叉链表作为存储结构,完成二叉的建立,前序、中序和后序遍历的操作,求所有叶子及结点总数的操作等。 具体要求如下: ①给出基于二叉链表的二叉类的定义; ②给出二叉初始化(构造函数)的实现; ③给出二叉三种遍历算法的递归实现; ④二叉先序遍历的非递归算法实现; ⑤利用二叉的遍历算法求二叉的结点数、二叉的叶结点数、二叉的高度; ⑥二叉的撤销删除 三、实验步骤: 1、需求分析: 本演示程序用JAVA编写,完成的生成,任意位置的插入、删除,以及遍历二叉中的结点,查找和修改中元素的值。 ① 输入的形式和输入值的范围:插入元素时需要输入插入的位置和元素的值;删除元素时输入删除元素的位置;遍历时采用三种遍历方法中的一种遍历方法;修改操作时需要输入的元素的值;查找操作时,需要找到要查找元素的位置。在所有输入中,元素的值都是整数。 ② 输出的形式:在所有四种操作中都显示操作是否正确以及操作中的内容。其中删除操作后显示删除的元素的值,遍历二叉中的元素,查找操作、修改操作后显示修改的值。 ③ 程序所能达到的功能:完成的生成(通过插入操作)、插入、删除、遍历、查找、修改操作。 ④ 测试数据: A. 中已有以50,25,75,12,37,43,30,33,87,93,97为关键字的结点 B. 插入操作中依次输入10,20,30,40,50,60,70,80,90,100十个数 C. 删除操作中输入10删除值为10的元素 D. 查找操作中输入20,30,40,50返回这个元素在中的位置 2.概要设计: 1)为了实现上述程序功能,需要定义的抽象数据类型: public int iData; public double dData; public Node leftChild; public Node rightChild; private Node root;int value; private Node getSuccessor; 基本操作:{ Tree () 操作结果:构造一个空的二叉 insert () 初始条件:是否存在一个空二叉 操作结果:往二叉中插入数值 delete () 初始条件:存在一非空的二叉 操作条件:将二叉中的元素删除 displayTree () 初始条件:存在一非空的 操作条件:显示非空中的所有元素的值 getString () 初始条件:存在一非空的二叉 操作结果:返回整个字符串的数值 getChar () 初始条件:存在一非空的二叉 操作结果:返回字符型的数值 getInt () 初始条件:存在一非空的二叉 操作结果:返回整型的数值 find () 初始条件:存在一非空二叉 操作结果:从二叉中查找某一元素 traverse () 初始条件:存在一非空的二叉 操作结果:对二叉中的元素进行遍历 preorder () 初始条件:存在一非空的二叉 操作结果:对二叉中的元素进行先根遍历 inOrder () 初始条件:存在一非空的二叉 操作结果:对二叉中的元素进行中根遍历 postOrder () 初始条件:存在一非空的二叉 操作结果:对二叉中的元素进行后根遍历 DisplayNode () 初始条件:存在一非空的二叉 操作结果:显示出二叉中的整形数值和双精度浮点型数值 public static void main 操作结果:调用主函数

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值