python数据结构树和二叉树简介


Posted in Python onApril 29, 2014

一、树的定义

树形结构是一类重要的非线性结构。树形结构是结点之间有分支,并具有层次关系的结构。它非常类似于自然界中的树。
树的递归定义:
树(Tree)是n(n≥0)个结点的有限集T,T为空时称为空树,否则它满足如下两个条件:
(1)有且仅有一个特定的称为根(Root)的结点;
(2)其余的结点可分为m(m≥0)个互不相交的子集Tl,T2,…,Tm,其中每个子集本身又是一棵树,并称其为根的子树(Subree)。

二、二叉树的定义

二叉树是由n(n≥0)个结点组成的有限集合、每个结点最多有两个子树的有序树。它或者是空集,或者是由一个根和称为左、右子树的两个不相交的二叉树组成。
特点:
(1)二叉树是有序树,即使只有一个子树,也必须区分左、右子树;
(2)二叉树的每个结点的度不能大于2,只能取0、1、2三者之一;
(3)二叉树中所有结点的形态有5种:空结点、无左右子树的结点、只有左子树的结点、只有右子树的结点和具有左右子树的结点。

三、二叉树的性质

性质1:二叉树的第i层上最多有个结点。
性质2:深度为h的二叉树上最多有-1个结点。
性质3:具有n个结点的二叉树的高度不小于的最大整数。
性质4:任意一棵二叉树中,如果叶子结点的个数为n0,度为2的结点的个数为n2,则必然有n0=n2+1。
满二叉树:若深度为h的二叉树,恰好具有-1个结点,则称为满二叉树。
完全二叉树:若一棵具有n个结点的二叉树的逻辑结构与满二叉树的前n个结点的逻辑结构完全相同,则称该二叉树为完全二叉树
扩充二叉树:除叶子结点外,其余结点都必须有两个孩子的二叉树。

四、二叉树的存储结构

二叉树的存储结构有顺序存储结构、链式存储结构
顺序存储:结构采用一维数组存储的。根据二叉树的性质6可计算出双亲结点、左右孩子结点的下标。因此满二叉树、完全二叉树的存储可采用一维数组,把结点按从上到下、从左到右的顺序存放在数组中,结点之间的关系可由性质6的公式计算得到。
链式存储:结构采用链表存储二叉树中的数据元素,用链建立二叉树中结点之间的关系。二叉树最常用的链式存储结构是二叉链,每个结点包含三个域,分别是数据元素域data、左孩子链域lChild和右孩子链域rChild。与单链表带头结点和不带头结点的两种情况相似,二叉链存储结构的二叉树也有带头结点和不带头结点两种

五、二叉树的操作

Python 相关文章推荐
Python深入学习之特殊方法与多范式
Aug 31 Python
python抽象基类用法实例分析
Jun 04 Python
Python抓取手机号归属地信息示例代码
Nov 28 Python
Python实现压缩和解压缩ZIP文件的方法分析
Sep 28 Python
Python分支结构(switch)操作简介
Jan 17 Python
python Web开发你要理解的WSGI & uwsgi详解
Aug 01 Python
python+webdriver自动化环境搭建步骤详解
Jun 03 Python
python判断所输入的任意一个正整数是否为素数的两种方法
Jun 27 Python
Python在cmd上打印彩色文字实现过程详解
Aug 07 Python
Python散点图与折线图绘制过程解析
Nov 30 Python
Django restframework 框架认证、权限、限流用法示例
Dec 21 Python
新手常见Python错误及异常解决处理方案
Jun 18 Python
Python的ORM框架SQLAlchemy入门教程
Apr 28 #Python
Python中实现远程调用(RPC、RMI)简单例子
Apr 28 #Python
Python的ORM框架SQLObject入门实例
Apr 28 #Python
django自定义Field实现一个字段存储以逗号分隔的字符串
Apr 27 #Python
python监控网卡流量并使用graphite绘图的示例
Apr 27 #Python
python抓取网页图片示例(python爬虫)
Apr 27 #Python
python实现sublime3的less编译插件示例
Apr 27 #Python
You might like
《Re:从零开始的异世界生活》剧情体验,手游新作定名
2020/04/09 日漫
php中filter_input函数用法分析
2014/11/15 PHP
PHP实现的同步推荐操作API接口案例分析
2016/11/30 PHP
javascript getElementsByTagName
2011/01/31 Javascript
jQuery 追加元素的方法如append、prepend、before
2014/01/16 Javascript
使用 TypeScript 重新编写的 JavaScript 坦克大战游戏代码
2015/04/07 Javascript
分享js粘帖屏幕截图到web页面插件screenshot-paste
2020/08/21 Javascript
BootStrap中的table实现数据填充与分页应用小结
2016/05/26 Javascript
JS及PHP代码编写八大排序算法
2016/07/12 Javascript
微信小程序的日期选择器的实例详解
2017/09/29 Javascript
JS实现的数组去除重复数据算法小结
2017/11/17 Javascript
JS数组去重常用方法实例小结【4种方法】
2018/05/28 Javascript
深入理解Promise.all
2018/08/08 Javascript
layui监听单元格编辑前后交互的例子
2019/09/16 Javascript
Vue实现商品飞入购物车效果(电商项目)
2019/11/26 Javascript
微信小程序利用云函数获取手机号码
2019/12/17 Javascript
es6中使用map简化复杂条件判断操作实例详解
2020/02/19 Javascript
微信小程序文章详情功能完整实例
2020/06/03 Javascript
js 将多个对象合并成一个对象 assign方法的实现
2020/09/24 Javascript
简单介绍Python中的JSON使用
2015/04/28 Python
python 获取字符串MD5值方法
2018/05/29 Python
解决Python2.7中IDLE启动没有反应的问题
2018/11/30 Python
python简单实现AES加密和解密
2019/03/28 Python
Python获取数据库数据并保存在excel表格中的方法
2019/06/12 Python
对python3.4 字符串转16进制的实例详解
2019/06/12 Python
python绘制直方图和密度图的实例
2019/07/08 Python
python通过文本在一个图中画多条线的实例
2020/02/21 Python
查看已安装tensorflow版本的方法示例
2020/04/19 Python
详解Python中如何将数据存储为json格式的文件
2020/11/18 Python
linux面试题参考答案(10)
2013/11/04 面试题
库房管理员岗位职责
2014/03/09 职场文书
铁路安全事故反思
2014/04/26 职场文书
小学重阳节活动总结
2015/03/24 职场文书
行政人事专员岗位职责
2015/04/07 职场文书
党员转正大会主持词
2015/07/02 职场文书
POST提交数据常见的四种方式
2022/01/18 HTML / CSS