返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >C语言中二叉树的常见操作是什么
  • 833
分享到

C语言中二叉树的常见操作是什么

2023-06-08 08:06:12 833人浏览 薄情痞子
摘要

这篇文章主要讲解了“C语言中二叉树的常见操作是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C语言中二叉树的常见操作是什么”吧!一、基本概念每个结点最多有两棵子树,左子树和右子树,次序不

这篇文章主要讲解了“C语言二叉树的常见操作是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C语言中二叉树的常见操作是什么”吧!

一、基本概念

每个结点最多有两棵子树,左子树和右子树,次序不可以颠倒。

性质:

1、非空二叉树的第n层上至多有2^(n-1)个元素。

2、深度为h的二叉树至多有2^h-1个结点。

满二叉树:所有终端都在同一层次,且非终端结点的度数为2。

在满二叉树中若其深度为h,则其所包含的结点数必为2^h-1。

完全二叉树:除了最大的层次即成为一颗满二叉树且层次最大那层所有的结点均向左靠齐,即集中在左面的位置上,不能有空位置。

对于完全二叉树,设一个结点为i则其父节点为i/2,2i为左子节点,2i+1为右子节点。

二、存储结构

顺序存储:

数据结构存在一块固定的数组中。

#define LENGTH 100typedef char datatype;typedef struct node{  datatype data;  int lchild,rchild;  int parent;}Node;Node tree[LENGTH];int length;int root;

虽然在遍历速度上有一定的优势,但因所占空间比较大,是非主流二叉树。二叉树通常以链式存储。

链式存储:

typedef char datatype;typedef struct BinNode{  datatype data;  struct BinNode* lchild;  struct BinNode* rchild;}BinNode;typedef BinNode* bintree;     //bintree本身是个指向结点的指针

三、二叉树的遍历

遍历即将树的所有结点访问且仅访问一次。按照根节点位置的不同分为前序遍历,中序遍历,后序遍历。

前序遍历:根节点->左子树->右子树

中序遍历:左子树->根节点->右子树

后序遍历:左子树->右子树->根节点

例如:求下面树的三种遍历

C语言中二叉树的常见操作是什么

前序遍历:abdefGC

中序遍历:debgfac

后序遍历:edgfbca

四、遍历的实现

递归实现(以前序遍历为例,其他的只是输出的位置稍有不同)

void preorder(bintree t){  if(t){    printf("%c ",t->data);    preorder(t->lchild);    preorder(t->rchild);  }}

非递归的实现

因为当遍历过根节点之后还要回来,所以必须将其存起来。考虑到后进先出的特点,选用栈存储。数量确定,以顺序栈存储。

#define SIZE 100typedef struct seqstack{  bintree data[SIZE];  int tag[SIZE];  //为后续遍历准备的  int top;   //top为数组的下标}seqstack;void push(seqstack *s,bintree t){  if(s->top == SIZE){    printf("the stack is full\n");  }else{    s->top++;    s->data[s->top]=t;  }}bintree pop(seqstack *s){  if(s->top == -1){    return NULL;  }else{    s->top--;    return s->data[s->top+1];  }}

1、前序遍历

void preorder_dev(bintree t){  seqstack s;  s.top = -1;   //因为top在这里表示了数组中的位置,所以空为-1  if(!t){    printf("the tree is empty\n");  }else{    while(t || s.stop != -1){      while(t){  //只要结点不为空就应该入栈保存,与其左右结点无关         printf("%c ",t->data);        push(&s,t);        t= t->lchild;      }      t=pop(&s);      t=t->rchild;    }  }}

2、中序遍历

void midorder(bintree t){  seqstack s;  s.top = -1;  if(!t){    printf("the tree is empty!\n");  }else{    while(t ||s.top != -1){      while(t){        push(&s,t);        t= t->lchild;      }      t=pop(&s);      printf("%c ",t->data);      t=t->rchild;    }  }}

3、后序遍历

因为后序遍历最后还要要访问根结点一次,所以要访问根结点两次。采取夹标志位的方法解决这个问题。

这段代码非常纠结,对自己有信心的朋友可以尝试独立写一下。反正我是写了很长时间。逻辑不难,我画了一张逻辑图:

C语言中二叉树的常见操作是什么

代码:

void postorder_dev(bintree t){  seqstack s;  s.top = -1;  if(!t){    printf("the tree is empty!\n");  }else{    while(t || s.top != -1){  //栈空了的同时t也为空。      while(t){        push(&s,t);        s.tag[s.top] = 0;  //设置访问标记,0为第一次访问,1为第二次访问        t= t->lchild;      }      if(s.tag[s.top] == 0){ //第一次访问时,转向同层右结点        t= s.data[s.top];  //左走到底时t是为空的,必须有这步!        s.tag[s.top]=1;        t=t->rchild;      }else {        while (s.tag[s.top] == 1){ //找到栈中下一个第一次访问的结点,退出循环时并没有pop所以为其左子结点          t = pop(&s);          printf("%c ",t->data);        }        t = NULL; //必须将t置空。跳过向左走,直接向右走      }    }  }}

4、层次遍历:即每一层从左向右输出

元素需要储存有先进先出的特性,所以选用队列存储。

队列的定义:

#define MAX 1000typedef struct seqqueue{  bintree data[MAX];  int front;  int rear;}seqqueue;void enter(seqqueue *q,bintree t){  if(q->rear == MAX){    printf("the queue is full!\n");  }else{    q->data[q->rear] = t;    q->rear++;  }}bintree del(seqqueue *q){  if(q->front == q->rear){    return NULL;  }else{    q->front++;    return q->data[q->front-1];  }}

遍历实现

void level_tree(bintree t){  seqqueue q;  bintree temp;  q.front = q.rear = 0;  if(!t){    printf("the tree is empty\n");    return ;  }  enter(&q,t);  while(q.front != q.rear){    t=del(&q);    printf("%c ",t->data);    if(t->lchild){      enter(&q,t->lchild);    }    if(t->rchild){      enter(&q,t->rchild);    }  }}

5、利用前序遍历的结果生成二叉树

//递归调用,不存点,想的时候只关注于一个点,因为还会回来的,不要跟踪程序运行,否则容易多加循环void createtree(bintree *t){  datatype c;  if((c=getchar()) == '#')    *t = NULL;  else{    *t = (bintree)malloc(sizeof(BinNode));    (*t)->data = c;    createtree(&(*t)->lchild);    createtree(&(*t)->rchild);  }}

6、二叉树的查找

bintree search_tree(bintree t,datatype x){  if(!t){    return NULL;  }  if(t->data == x){    return t;  }else{    if(!search_tree(t->lchild,x)){      return search_tree(t->rchild,x);    }    return t;  }}

7、统计结点个数

int count_tree(bintree t){  if(t){    return (count_tree(t->lchild)+count_tree(t->rchild)+1);  }  return 0;}

8、比较两个树是否相同

int is_equal(bintree t1,bintree t2){  if(!t1 && !t2){   //都为空就相等    return 1;  }  if(t1 && t2 && t1->data == t2->data){   //有一个为空或数据不同就不判断了    if(is_equal(t1->lchild,t2->lchild))      if(is_equal(t1->rchild,t2->rchild)){        return 1;      }  }  return 0;}

9、求二叉树的深度

int hight_tree(bintree t){  int h,left,right;  if(!t){    return 0;  }  left = hight_tree(t->lchild);  right = hight_tree(t->rchild);  h = (left>right?left:right)+1;  return h;}

感谢各位的阅读,以上就是“C语言中二叉树的常见操作是什么”的内容了,经过本文的学习后,相信大家对C语言中二叉树的常见操作是什么这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

--结束END--

本文标题: C语言中二叉树的常见操作是什么

本文链接: https://lsjlt.com/news/253022.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • C语言中二叉树的常见操作是什么
    这篇文章主要讲解了“C语言中二叉树的常见操作是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C语言中二叉树的常见操作是什么”吧!一、基本概念每个结点最多有两棵子树,左子树和右子树,次序不...
    99+
    2023-06-08
  • C语言二叉树的操作方法
    本篇内容主要讲解“C语言二叉树的操作方法”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“C语言二叉树的操作方法”吧!二叉树分类满二叉树除最后一层无任何子节点外,每一层上的所有结点都有两个子结点的二...
    99+
    2023-06-30
  • C语言实现BST二叉排序树的基本操作
    本文实例为大家分享了C语言实现BST二叉排序树的基本操作代码,供大家参考,具体内容如下 BST-二叉排序树的几个基本操作。 头文件声明与函数定义 #include <std...
    99+
    2024-04-02
  • C语言链式二叉树结构原理是什么
    这篇文章主要介绍“C语言链式二叉树结构原理是什么”,在日常操作中,相信很多人在C语言链式二叉树结构原理是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”C语言链式二叉树结构原理是什么”的疑惑有所帮助!接下来...
    99+
    2023-06-25
  • C语言数据结构详细解析二叉树的操作
    目录二叉树分类二叉树性质性质的使用二叉树的遍历前序遍历中序遍历后序遍历层序遍历求二叉树的节点数求二叉树叶子结点个数求二叉树的最大深度二叉树的销毁二叉树分类 满二叉树 除最后一层无任何...
    99+
    2024-04-02
  • C语言之二叉树的遍历
    目录0.写在前面1.前序遍历步骤详解代码实现2.中序遍历步骤详解代码实现3.后序遍历步骤详解代码实现0.写在前面 认识二叉树结构最简单的方式就是遍历二叉树。所谓遍历二叉树就是按照某种...
    99+
    2023-05-14
    C语言实现二叉树遍历 二叉树遍历
  • C语言中常见的文件操作方法是什么
    今天小编给大家分享一下C语言中常见的文件操作方法是什么的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。1.为什么使用文件大家在...
    99+
    2023-07-02
  • C语言二叉树的概念是什么及怎么使用
    本篇内容主要讲解“C语言二叉树的概念是什么及怎么使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“C语言二叉树的概念是什么及怎么使用”吧!1.二叉树的概念及结构 ①概念:一棵二叉树是结...
    99+
    2023-06-29
  • C语言中二叉树的示例分析
    这篇文章主要为大家展示了“C语言中二叉树的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“C语言中二叉树的示例分析”这篇文章吧。树概念及结构树是一种 非线性 的数据结构,它是由 n ( n...
    99+
    2023-06-29
  • 深入探究C语言中的二叉树
    目录1.树概念及结构1.1树的概念 1.2 树的相关概念1.3 树的表示2.二叉树概念及结构   2.1概念2.2 特殊的二叉树2.3 二叉树的性质&n...
    99+
    2023-05-19
    C语言二叉树 C语言数据结构
  • C语言中二叉查找树怎么实现
    本文小编为大家详细介绍“C语言中二叉查找树怎么实现”,内容详细,步骤清晰,细节处理妥当,希望这篇“C语言中二叉查找树怎么实现”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。二叉查找树性质1、二叉树每个树的节点最多有...
    99+
    2023-06-16
  • C语言数据结构系列篇二叉树的概念及满二叉树与完全二叉树
    链接:C语言数据结构系列之树的概念结构和常见表示方法 0x00 概念 定义:二叉树既然叫二叉树,顾名思义即度最大为2的树称为二叉树。 它的度可以为 1 也可...
    99+
    2024-04-02
  • C语言中关于树和二叉树的相关概念
    目录一、树树的相关概念树的存储结构二、二叉树二叉树的性质树是一种 非线性的 数据结构,由 n(n >= 0) 个 有限节点 组成一种 具有层次关系 的集合 一、树 树的结构可以...
    99+
    2023-02-14
    C语言树和二叉树的概念 C语言树和二叉树
  • C++二叉搜索树的操作有哪些
    本文小编为大家详细介绍“C++二叉搜索树的操作有哪些”,内容详细,步骤清晰,细节处理妥当,希望这篇“C++二叉搜索树的操作有哪些”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。二叉搜索树概念与操作二叉搜索树的概念二...
    99+
    2023-06-29
  • C++ LeeCode二叉树的中序遍历是什么
    这篇文章主要介绍了C++ LeeCode二叉树的中序遍历是什么的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇C++ LeeCode二叉树的中序遍历是什么文章都会有所收获,下面我们一起来看看吧。一、题目二、代码c...
    99+
    2023-06-19
  • C语言中二叉树的后序遍历详解
    目录一.二叉树的后序遍历.(递归)二.二叉树的后序遍历(迭代)总结首先我们从两个方面讲解二叉树的后序遍历(递归+迭代) 一.二叉树的后序遍历.(递归) 思想: 首先我们从二叉树的根节...
    99+
    2024-04-02
  • c语言二叉树怎么创建与遍历
    在C语言中,可以使用结构体来表示二叉树节点,然后通过递归的方式来创建和遍历二叉树。 首先定义一个结构体表示二叉树节点: struct...
    99+
    2024-04-02
  • c语言二叉树的前序遍历方法
    这篇文章主要讲解了“c语言二叉树的前序遍历方法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“c语言二叉树的前序遍历方法”吧!题目给定一个二叉树,返回它的 前序 遍历。示例:输入: [1,nu...
    99+
    2023-06-19
  • C语言平衡二叉树的示例分析
    这篇文章给大家分享的是有关C语言平衡二叉树的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。平衡二叉树(Balanced Binary Tree)又被称为AVL树(有别于AVL算法),且具有以下性质:它是一...
    99+
    2023-06-25
  • C语言二叉树的概念结构详解
    目录1、树的概念及结构(了解)1.1树的概念:1.2树的表示法:2、二叉树的概念及结构2.1二叉树的概念2.2特殊的二叉树2.2二叉树的性质2.3二叉树的顺序存储2.4二叉树的链式存...
    99+
    2022-11-13
    C语言二叉树 C语言二叉树的创建
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作