数据结构之二叉树

二叉树专题


#树的定义:
树是n个结点的有限集。n等于0是称为空树,在任意一棵非空树中,有且仅有 一个特定的称为根的结;当n>1时,其余节点可分为m(m>0)个互不相交的有限集,其中每个集合本身又是一棵树,并且称为根的子树。
在这里插入图片描述
#二叉树基本概念

满二叉树:一棵深度为k 且有2k -1个结点的二叉树。
(特点:每层都“充满”了结点)
完全二叉树:深度为k 的,有n个结点的二叉树,当且仅当其每一个结点都与深度为k 的满二叉树中编号从1至n的结点一一对应。
在这里插入图片描述

#二叉树的存储结构
顺序存储结构:按二叉树的结点“自上而下,从左到右”编号,用一组连续的存储单元存储。如果是完全二叉树,能够恢复唯一对应的二叉树形状
链式存储结构:
typedef struct node{ //树的结点
int data;
struct node* left;
struct node* right;
} Node;

#二叉树的遍历
二叉树由根、左子树、右子树构成,定义为D、L、R,所以根据访问的根结点是先于子树出现还是后于子树出现,分为先、中、后三种遍历方式.
在这里插入图片描述

#import <Foundation/Foundation.h>
#include <stdio.h>
#include <stdlib.h>

typedef struct TreeNode{
    char ch;
    struct TreeNode *lchild, *rchild;
}Tree, *PTree;//定义树节点的结构体

void createBiTree(PTree *p)//建立二叉树
{
    char ch;
    scanf("%c", &ch);
    getchar();//此时%c读取的是单个字符,所以用那个getchar来接收一下
    if(ch == '#')
        *p = NULL;
    else
    {
        *p = (PTree)malloc(sizeof(Tree));
        (*p) -> ch = ch;
        printf("请输入%c的左子树\n", ch);
        createBiTree(&(*p) -> lchild);
        printf("请输入%c的右子树\n", ch);
        createBiTree(&(*p) -> rchild);
    }
}

void preOrderTraverse(PTree p)//前序遍历
{
    if(p == NULL)
        return ;
    printf("%c ", p -> ch);
    preOrderTraverse(p -> lchild);
    preOrderTraverse(p -> rchild);
}

void InOrderTraverse(PTree p)//中序遍历
{
    if(p == NULL)
        return;
    InOrderTraverse(p -> lchild);
    printf("%c ", p -> ch);
    InOrderTraverse(p -> rchild);
}

void BackOrderTraverse(PTree p)//后续遍历
{
    if(p == NULL)
        return ;
    BackOrderTraverse(p -> lchild);
    BackOrderTraverse(p -> rchild);
    printf("%c ", p -> ch);
}

int main(int argc, const char * argv[]) {
    @autoreleasepool {
        PTree pt;
        createBiTree(&pt);
        preOrderTraverse(pt);
        printf("\n");
        InOrderTraverse(pt);
        printf("\n");
        BackOrderTraverse(pt);
        printf("\n");
    }
    return 0;
}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值