数据结构(c++语言版) 邓俊辉 第五章:二叉树学习笔记

这篇具有很好参考价值的文章主要介绍了数据结构(c++语言版) 邓俊辉 第五章:二叉树学习笔记。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

5.1二叉树及其表示

        树是由节点和边组成的。

1.有根树

        树是由顶点(vertex)和边(edge)组成。树的每个顶点也叫节点(node)。

2.深度与层次

        由树的连通性,每一节点与根都有一条路径相连:根据树的无环性,由根通往每个节点的路径必然唯一。

        节点v的深度:每个节点到root的唯一通路所经过的边的数目,称作v的数目,记作depth(v)。

        约定 depth(r) = 0,其中r表示根节点。

祖先:任一节点通往树根所经过的每个节点都叫做v的祖先(ancestor),v是他们的后代(descendant)。特别地,v的祖先和后代包括v本身。v本身以外的祖先/后代称为v的真祖先(proper ancestor)/真后代(proper descendant)。

        父亲/孩子:u如果是v的祖先,且u比v高出一层。就称u是v的父亲。v是u的孩子。

        度:v的孩子的总数,称作v的度数或者度(degree),记作deg(v)。

        叶节点:无孩子的节点称为叶节点。(leaf node)。其余节点(包括根节点,叫做内部节点)。

        子树:v的所有后代及其连边所组成树称作子树(subtree),记作subtree(v)。

3.高度

        树T中所有节点深度最大值称作树的高度(height),记作height(H)。

        不难理解,树的高度(height),是由其中某个叶节点的深度决定的,特别地,本书约定,仅含单个节点的树的高度为0,空树的高度为-1。

        推而广之,任一节点v所对应子树subtree(v)的高度,亦称做该节点的高度,记作height(v)。特别地,全树的高度称作根节点的高度。即height(T) = height(r)。

5.1.2 二叉树

        数据结构(c++语言版) 邓俊辉 第五章:二叉树学习笔记,数据结构,c++,学习

 如图,二叉树的每个节点的度都不超过2。因此在二叉树中,每个节点的左右孩子都可以以左右区分——此时,亦称作有序二叉树(ordered binary tree)。特别地,不含一度节点的树,称做真二叉树(proper binary tree)。

5.1.3多叉树

        一般地,树中各节点孩子数目不确定,每个节点孩子均不超过k个的有根树,称做k叉树。

(1)父节点表示法

       数据结构(c++语言版) 邓俊辉 第五章:二叉树学习笔记,数据结构,c++,学习            数据结构(c++语言版) 邓俊辉 第五章:二叉树学习笔记,数据结构,c++,学习

 (2)孩子节点表示法

数据结构(c++语言版) 邓俊辉 第五章:二叉树学习笔记,数据结构,c++,学习

数据结构(c++语言版) 邓俊辉 第五章:二叉树学习笔记,数据结构,c++,学习

(3)父节点+孩子节点表示法数据结构(c++语言版) 邓俊辉 第五章:二叉树学习笔记,数据结构,c++,学习

数据结构(c++语言版) 邓俊辉 第五章:二叉树学习笔记,数据结构,c++,学习

        文章来源地址https://www.toymoban.com/news/detail-640842.html

        

        

到了这里,关于数据结构(c++语言版) 邓俊辉 第五章:二叉树学习笔记的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 王道考研数据结构第五章知识点

    5.1.1 树的定义和基本术语   祖先节点:(对于你来说),父亲和爷爷都是祖先节点 子孙节点:对于父亲来说,父亲下面所有的节点都叫子孙节点 双亲节点(父节点):一个节点的直接前驱就是它的父节点  兄弟节点:例如二叔,三叔都是父亲的兄弟节点 堂兄弟节点:对于你来说,

    2024年02月15日
    浏览(51)
  • 数据结构与算法分析 第五章 树和二叉树 作业讲解

     参考教材: 《数据结构(C语言版 第2版)》 严蔚敏,李冬梅,吴伟民编著,人民邮电出版社,2022年版。 截图未标明出处均为原创或取自《数据结构(C语言版 第2版)》~   本文对应的作业题讲解视频:   数据结构与算法分析作业讲解视频合集 https://www.bilibili.com/video/BV1N

    2024年02月02日
    浏览(38)
  • 【Rust】Rust学习 第五章使用结构体组织相关联的数据

    定义结构体,需要使用  struct  并为整个结构体提供一个名字。结构体的名字需要描述它所组合的数据的意义。接着,在大括号中,定义每一部分数据的名字和类型,我们称为  字段 ( field )。 实例化(不可变变量) 可变变量 字段初始化简写语法 通过已经存着的变

    2024年02月13日
    浏览(48)
  • 数据结构英文习题解析-第五章 二叉搜索树Binary Search Tree

    前言:最近快到FDS考试了,po重刷了一下学校的题目,自己整理了一些解析orz 因为po在自己找解析和学习的过程中非常痛苦,所以在此共享一下我的题目和自己写的解题思路,欢迎各位指出错误~全章节预计会陆续更新,可在专栏查看~ HW5 1.In a binary search tree, the keys on the same

    2024年04月09日
    浏览(48)
  • 数据结构与算法教程,数据结构C语言版教程!(第五部分、数组和广义表详解)三

    数组和广义表,都用于存储逻辑关系为“一对一”的数据。 数组存储结构,99% 的编程语言都包含的存储结构,用于存储不可再分的单一数据;而广义表不同,它还可以存储子广义表。 本章重点从矩阵的角度讨论二维数组的存储,同时讲解广义表的存储结构以及有关其广度和

    2024年01月21日
    浏览(48)
  • 数据结构与算法教程,数据结构C语言版教程!(第五部分、数组和广义表详解)五

    数组和广义表,都用于存储逻辑关系为“一对一”的数据。 数组存储结构,99% 的编程语言都包含的存储结构,用于存储不可再分的单一数据;而广义表不同,它还可以存储子广义表。 本章重点从矩阵的角度讨论二维数组的存储,同时讲解广义表的存储结构以及有关其广度和

    2024年01月23日
    浏览(49)
  • 【第五周】数据结构

    1. 进制转换问题 【问题描述】根据课堂讲授,请用“顺序栈”解决进制转换问题,不采用顺序栈,不给分。 【输入形式】十进制数据和待转换的进制 【输出形式】转换后的数据 【样例输入1】1348 8 【样例输出1】2504 【样例输入2】2608 16 【样例输出2】A30 2. 字符串镜像 【问题

    2024年02月06日
    浏览(32)
  • 第五章 结构化设计

    一种软件开发活动,定义实现需求规约所需的软件结构。 结构化设计分为: (1)总体设计:确定系统的整体模块结构,即系统实现所需要的软件模块以及这些模块之间的调用关系。 (2)详细设计:详细描述模块。 体系结构设计(MSD) 接口设计 数据设计 实现软件设计的目标对结

    2024年02月08日
    浏览(59)
  • JAVA学习笔记——第五章 控制结构

    🔥 博客主页 : A_SHOWY 🎥 系列专栏 :力扣刷题总结录 数据结构  云计算  数字图像处理  力扣每日一题_  流程控制总体介绍:决定程序是如何执行的,主要包括顺序控制、分支控制和循环控制 顺序控制:程序从上到下逐行执行,没有任何判断跳转 一个变量必须要先定

    2024年01月23日
    浏览(42)
  • 【数据结构初阶】第五节.栈的详讲

    提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言 一、栈的基本认识 二、栈模拟实现:  三、栈的实战演练 3.1 有效的括号 3.2 逆波兰表达式 3.3 栈的压入、弹出序列 总结 上一节内容我们学习了链表的有关内容,今天我们将进行栈的学习

    2023年04月23日
    浏览(48)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包