当前位置: 首页 > news >正文

网站建设需求量大房产cms系统哪个好

网站建设需求量大,房产cms系统哪个好,中国建行官方网站,免费提升学历目录 0.前言 1.树的认识 什么是树 树的相关概念 树的表示 孩子兄弟表示法 2.二叉树的认识 什么是二叉树 特殊的二叉树 满二叉树 完全二叉树 二叉树的性质 性质一 性质二 性质三 二叉树的存储 顺序存储 链式存储 0.前言 笔者我之前讲解的数据结构都是线性…

目录

0.前言

1.树的认识

什么是树

树的相关概念

树的表示

孩子兄弟表示法

2.二叉树的认识 

什么是二叉树

特殊的二叉树 

满二叉树

完全二叉树

二叉树的性质

性质一

性质二

性质三 

二叉树的存储

顺序存储

链式存储


0.前言

笔者我之前讲解的数据结构都是线性的数据结构,比如:顺序表、链表、栈、队列。线性结构中存储的元素在逻辑上像是被一条线串起来的一样。现在我将介绍一种非线性的数据结构 —— 二叉树,但是介绍二叉树之前需要介绍一下树,因为二叉树是树的一种特殊情况。

1.树的认识

什么是树

树是一种非线性的数据结构,它是由n(n>=0)个有限结点组成一个具有层次关系的集合。之所以把它叫做树,是因为这种数据结构看起来像一棵倒过来的树,根朝上,叶朝下,如下图所示。

  • 从上往下的第一个结点叫做根结点
  • 除根节点外,其余结点被分成m (m>0) 个互不相交的集合T1、T2、……、Tm,其中每一个集合Ti(1<= i<= m) 又是一棵结构与树类似的子树。每棵子树的根结点有且只有一个前驱,可以有0个或多个后继。

注意:树形结构中,子树之间不能有交集,否则就不是树!变成了另一种数据结构 —— 图。

这就不是一棵树:

树的相关概念

  • 节点的度:一个节点含有的子树的个数称为该节点的度; 如上图:A的为6
  • 叶节点或终端节点度为0的节点称为叶节点; 如上图:B、C、H、I...等节点为叶节点
  • 非终端节点或分支节点度不为0的节点; 如上图:D、E、F、G...等节点为分支节点
  • 双亲节点或父节点:若一个节点含有子节点,则这个节点称为其子节点的父节点; 如上图:A是B的父节点
  • 孩子节点或子节点:一个节点含有的子树的根节点称为该节点的子节点; 如上图:B是A的孩子节点
  • 兄弟节点:具有相同父节点的节点互称为兄弟节点; 如上图:B、C是兄弟节点
  • 树的度:一棵树中,最大的节点的度称为树的度; 如上图:树的度为6
  • 节点的层次:从根开始定义起,根为第1层,根的子节点为第2层,以此类推;
  • 树的高度或深度:树中节点的最大层次; 如上图:树的高度为4
  • 堂兄弟节点:双亲在同一层的节点互为堂兄弟;如上图:H、I互为兄弟节点
  • 节点的祖先从根到该节点所经分支上的所有节点;如上图:A是所有节点的祖先
  • 子孙:以某节点为根的子树中任一节点都称为该节点的子孙。如上图:所有节点都是A的子孙
  • 森林:由m(m>0)棵互不相交的树的集合称为森林;

树的表示

表示一棵树说的就是用代码如何表示一棵树。前面列出的图都是树的逻辑图,也就是说,在逻辑上,我们希望他是这样的。表示树的时候,既要保存值域,也要保存结点和结点之间的关系,基于这点,实现起来是比较麻烦的,但是有人发明了如下几种表示树的方式。

  • 双亲表示法:每个结点都记录自己的双亲。
  • 孩子表示法:每个结点都记录自己的孩子。
  • 孩子双亲表示法:每个结点既记录自己的孩子,也记录自己的双亲。
  • 孩子兄弟表示法:每个结点既记录自己的孩子,也记录自己的兄弟。

其中最常用的是孩子兄弟表示法

孩子兄弟表示法

孩子兄弟表示法说的就是,每个结点记录从左往右数的第一个孩子结点自己后面的第一个兄弟结点。

每个结点的定义如下:

逻辑图如下:

2.二叉树的认识 

什么是二叉树

二叉树是一种特殊的树,特殊的地方就在于二叉树每个结点的度最大为二。一棵二叉树是结点的一个有限集合,该集合必须具有以下条件之一:

  • 或者为空。
  • 或者由一个根节点加上两棵别称为左子树和右子树的二叉树组成。

二叉树的逻辑图如下所示:

特殊的二叉树 

在所有的二叉树中,有那么两种特殊的二叉树满二叉树完全二叉树

满二叉树

每一层结点都达到最大值的二叉树就是满二叉树。

如下图所示:

对于满二叉树而言,一个具有k层的满二叉树的结点个数为2^k-1个。 

完全二叉树

完全二叉树是由满二叉树引申出来的,当一棵高度为k的二叉树的所有结点都能连续地、和高度为k的满二叉树中的节点一 一对应,这棵树就是完全二叉树。

  • 满二叉树是一种特殊的完全二叉树。

二叉树的性质

性质一

对任何一棵二叉树,如果度为0其叶结点个数为n0,度为2的分支结点个数为n2,则有 n0 = n2+1。

性质二

若规定根结点的层数为第 1 层:

  • 则一棵非空二叉树的第 i 层上最多有2^(i-1)个结点。
  • 则深度为 h 的二叉树的最大结点数是2^h-1
  • 若规定根节点的层数为第1层,具有n个结点的满二叉树的深度为h。

性质三 

对于具有n个结点的完全二叉树,如果按照从上至下从左至右的数组顺序对所有节点从0开始编号,则对于序号为 i 的结点有以下结论:

  • 若 i > 0,序号为 i 的结点的双亲结点的编号为 (i-1) / 2。(若i==0,i为根结点,无双亲结点)
  • 若2*i+1 < n,左孩子序号为2*i+1;若2*i+1 >= n,则无左孩子。
  • 若2*i+2 < n,右孩子序号为2*i+2;若2*i+2 >= n,则无右孩子。

二叉树的存储

对于二叉树,一般可以使用两种存储结构来存储,分别是顺序存储结构链式存储结构

顺序存储

二叉树顺序存储指的是使用顺序结构存储二叉树,其实就是使用数组存储;具体做法是对二叉树的每个结点从0开始编号,数据存储在和编号一致的数组下标空间上。

上述性质三其实就是二叉树顺序存储的性质。

使用数组存储二叉树的时候,数据构成的集合在逻辑上是二叉树,物理空间上使用的是数组存储。

完全二叉树顺序存储示意图: 

使用数组存储二叉树有个很明显的缺点就是,当存储的二叉树不是完全二叉树的时候,会有空间的浪费,并且这种浪费是不能避免的。 

非完全二叉树顺序存储示意图:

所以:使用数组存储二叉树的时候,只适合存储完全二叉树。

在实际应用中,只有堆才会使用数组存储二叉树,后面讲解。

链式存储

二叉树链式存储指的是用链表来存储二叉树。具体的做法是链表中每个结点由3个域组成,数据域和左右指针域,左右指针域分别用来存储左孩子的地址和右孩子的地址。

二叉树结点表示:

二叉树链式存储结构示意图: 

http://www.yayakq.cn/news/906252/

相关文章:

  • 网站改名 备案wordpress默认登录页修改
  • 自己做的网站如何让百度收录宁夏免费做网站
  • 公司注册网站需要提供什么文件淄博周村专业网站建设公司
  • 二手书店网站建设项目规划书有没有好的做海报的网站
  • php网站开发工程师笔试国内对企业网站开发的研究
  • 泰安网络推广 网站建设 网站优化如东建设网站
  • 做网站需要考虑哪些问题北京设计院排名前十强
  • 十大门户网站有哪些南京市住房和城乡建设部网站
  • 常州做网站需要多少钱手机网站制作良心服务
  • 个人博客网站制作教程域名会跳转怎么进原网站
  • 淘宝客网站域名谁会做云南住房与城乡建设厅网站
  • 路由侠怎么做网站映射wordpress定制器
  • 网站策划推广方案wordpress参数传递的函数
  • 什么公司做企业网站12380网站建设意见
  • 站内优化无限免费视频直播
  • 国际论坛网站模板网站建设与维护就业前景
  • 天津网站建设培训班seo建站工具
  • 深圳建设工程交易网站官网平面设计与网站开发的概述
  • 怎么给自己的网站设置关键词西安企业网站建设价格
  • 网站建设山东wordpress查询数据库
  • flash网站开发框架品牌建设经费投入占比
  • 网站指定关键词优化wordpress 主题 简介
  • 深圳网站设计与制作公司顺德制作网站价格多少
  • 锦州网站建设市场西安做网站要多少钱
  • 群晖nas可以做网站写作网站后台账号密码忘了怎么办
  • 网站删除模块汕头站扩建什么时候完成
  • 苏州网站建设排行郑州冬青街 网站建设
  • 做宣传图册在什么网站seo营销论文
  • 昆山做网站优化php网站开发案例教程ppt
  • 服装厂做1688网站效果好不好网站分站怎么做