数据结构:树/二叉树

一、树的概念

逻辑结构:层次结构,一对多

  1. 节点:树中的一个数据元素
  2. 根节点:树中的第一个节点,没有父节点
  3. 孩子节点:该节点的直接下级节点
  4. 父(亲)节点:该结点的直接上级节点
  5. 兄弟节点:有相同父亲节点的
  6. 祖先节点:该结点的间接上级节点
  7. 子孙节点:该结点的间接下级节点
  8. 堂兄弟节点:有相同的祖先节点,在树的同一层的节点
  9. 树的深度:取树中层次的最大值
  10. 节点的度:子节点的个数/分支个数
  11. 树的度:节点度的最大值
  12. 森林:多个树(大于等于2)
  13. 节点的深度:从根节点开始向下的层次

二、 二叉树

节点的度最大为2

严格区分左右子树

1.二叉树的概念

  1. 二叉树的度:最大为2
  2. 左子树:节点左侧的子树
  3. 右子树:节点右侧的子树
  4. 满二叉树:除了叶子节点外,每一个节点的度都为0,叶子节点只能在最后一层
  5. 叶子节点:度为0的节点
  6. 完全二叉树:可以由满二叉树从右侧删除子树得到

2.二叉树的五种形态

3.二叉树的性质

第n层上最多有:2^(n-1)

前n层上:2^n-1

二叉树的总节点数:总度数+1         (其中+1,加的是头节点)

 4.二叉树的遍历

先序:根左右

中序:左根右

后序:左右根

练习1(一只一棵树的中序遍历和其他两种中任意一种,即可画唯一的二叉树)

先序:ABDGHCEFI            中序:GDHBAECIF

练习2.

 中序遍历:HDMIBJNEAFKCG      后序遍历:HMIDNJEBKFGCA

 

三、功能

二叉树的结构体

#ifndef __TREE_H__
#define __TREE_H__
#include <stdio.h>
#include <stdlib.h>typedef struct tree_node{char data;struct tree_node *lchild;//左孩子struct tree_node *rchild;//右孩子
}tree,*tree_p;//创建节点的函数
tree_p creat_node(char data);
//创建二叉树(创建节点,再创建节点的左右子树)
//二叉树的左右子树,仍然是一个二叉树
tree_p creat_tree();
//先序遍历:根左右
void pri(tree_p T);
//中序遍历:左根右
void zx(tree_p T);
//后序遍历:左右根
void hx(tree_p T);#endif

1.创建节点

//创建节点的函数
tree_p creat_node(char data){tree_p new=(tree_p)malloc(sizeof(tree));if(new==NULL){printf("申请空间失败\n");return NULL;}new->data=data;return new;
}

2.创建二叉树

//创建二叉树(创建节点,再创建节点的左右子树)
//二叉树的左右子树,仍然是一个二叉树
tree_p creat_tree(){char data='\0'; //定义一个char类型的变量初始化为'\0'//不然data就是一个随机值,防止随机为#scanf("%c",&data);getchar();//吸收垃圾字符if(data=='#'){  //#为停止字符return NULL;}tree_p T=creat_node(data);//创建根节点T->lchild=creat_tree();  //左子数仍然是一个子树T->rchild=creat_tree();return T;
}

3.先序遍历

//先序遍历:根左右
void pri(tree_p T){if(T==NULL){return;}printf("%c->",T->data);pri(T->lchild);//给根节点的左孩子调用先序遍历pri(T->rchild);//给根节点的右孩子调用先序遍历
}

4.中序遍历

//中序遍历:左根右
void zx(tree_p T){if(T==NULL){return;}zx(T->lchild);printf("%c->",T->data);zx(T->rchild);
}

5.后序遍历

//后序遍历:左右根
void hx(tree_p T){if(T==NULL){return;}hx(T->lchild);hx(T->rchild);printf("%c->",T->data);
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/496004.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

在GLviewwidget中添加文本,比如数字之类的

最近有个需求&#xff0c;想要在GLviewwidget里面的指定三维位置添加文本&#xff0c;但是找到的版本都太老久了&#xff0c;或者用的是open3d实现的&#xff0c;在实际中的应用效果并不是很好。因此自己就写了一个&#xff0c;代码如下&#xff1a; plot gl.GLTextItem(pos(…

亚信安慧AntDB数据库与流式处理的有机融合

流式处理的概念 2001年9月11日&#xff0c;美国世贸大楼被袭击&#xff0c;美国国防部第一次将“主动预警”纳入国防的宏观战略规划。而IBM作为当时全球最大的IT公司&#xff0c;承担了大量基础支撑软件研发的任务。其中2009年正式发布的IBM InfoSphere Streams&#xff0c;就是…

飞天使-学以致用-devops知识点1-安装gitlabharbor

文章目录 rpm 安装gitlab页面配置配置secretsecret 查看信息-chatgpt回复 为项目配置webhook,等jenkins部署完毕后在配置卸载 harbor配置secret所有k8s集群节点安装信任 http rpm 安装gitlab # 下载安装包 wget https://mirrors.tuna.tsinghua.edu.cn/gitlab-ce/yum/el7/gitla…

K8S之Deployment的介绍和使用

Deployment的理论和实操 Deployment控制器&#xff1a;概念、原理解读概述工作原理 编写Deployment资源清单文件使用案例&#xff1a;创建一个web站点Deployment管理pod&#xff1a;扩容、缩容通过deployment管理应用&#xff0c;实现扩容&#xff0c;把副本数变成3通过deploym…

mysql中创建外键只会在索引处出现解决办法

我在mysql中创建的外键总是不成功 只有索引的地方多了一条记录&#xff0c;外键那里一保存就没有了&#xff0c;也不报错 为什么会产生这个问题&#xff0c;这个坑的的来源是有以下三点&#xff1a; MySQL建表的时候&#xff0c;可以不指定表引擎&#xff0c; 这时候MySQL就会…

wpf 3d 后台加载模型和调整参数

下载了一个代码&#xff0c;加载obj模型&#xff1b;它的参数在xaml里&#xff0c;模型加载出来刚好&#xff1b; 然后加载另一个obj模型&#xff1b;加载出来之后大&#xff0c;偏到很高和左的位置&#xff1b; 它之前的摄像机位置&#xff0c; Position"9.94759830064…

2024土木工程、环境工业与材料科学国际会议(CEEIMS2024)

2024土木工程、环境工业与材料科学国际会议(CEEIMS2024) 一、【会议简介】 我们诚挚地邀请您参加2024年土木工程、环境工业与材料科学国际会议&#xff08;CEEIMS2024&#xff09;。本次会议将在厦门举行。 本次会议旨在为土木工程、环境工业和材料科学领域的专家学者提供一…

利用 ChatGPT 提升个人工作、生活品质

利用 ChatGPT 提升个人工作、生活品质和个人智慧是一个多方面而又切实可行的方法。 以下是一些具体的建议&#xff1a; 获取信息和知识&#xff1a; ChatGPT 可以回答各种问题并提供相关信息和知识。你可以利用它来查询工作中遇到的问题、学习新的知识领域或是获取日常生活中的…

Go的CSP并发模型实现M, P, G简介

GMP概念简介 G: goroutine&#xff08;协程&#xff0c;也叫用户态线程&#xff09; M: 工作线程(内核态线程) P: 上下文(也可以认为是cpu&#xff0c;逻辑cpu数量&#xff0c;可以在程序启动的时候设置这个数量&#xff0c;gomaxprocs函数设置) GMP 模型 在 Go 中&#xff…

el-table 多选表格存在分页,编辑再次操作勾选会丢失原来选中的数据

el-table表格多选时&#xff0c;只需要添加type"selection"&#xff0c; row-key及selection-change&#xff0c;如果存在分页时需要加上reserve-selection&#xff0c;这里就不写具体的实现方法了&#xff0c;可以查看我之前的文章&#xff0c;这篇文章主要说一下存…

CGI程序与ShellShock漏洞

CGI是什么&#xff1f; CGI&#xff08;通用网关接口&#xff0c;Common Gateway Interface&#xff09;程序是一种用于在Web服务器上执行动态内容的技术。与服务器上普通的后端代码相比&#xff0c;CGI程序有几个区别&#xff1a; 执行环境&#xff1a; CGI程序在服务器上作为…

开创5G无线新应用:笙科电子5.8GHz 射频芯片

笙科电子(AMICCOM) 5.8GHz A5133射频芯片是一款专门设计用于在5.8GHz频率范围内&#xff08;5725MHz - 5850MHz)进行射频信号处理的集成电路。这些集成电路通常包括各种功能模块&#xff0c;如射频前端、混合器、功率放大器、局部振荡器等&#xff0c;以支持无线通信系统的各种…