读数据结构与算法分析

树的概念

  • 一棵树是一些节点的集合,可以为空
  • 由称做根(root)的节点以及0个或多个非空子树组成,子树都被一条来自根的有向边相连

树的实现

思路

孩子兄弟表示法:树中的每个节点中除了数据为还有两个指针,一个指向其儿子,一个指向其兄弟。

树的节点声明

typedef struct TreeNode *PrtToNode ;

struct TreeNode
{
ElementType Element ;
PrtToNode FirstChild ;
PrtToNode NextSibling ;
}

树的遍历

先序遍历

以打印文件目录为例

void ListDir(DirectoryOrFile D,int Depth) //传进第一个目录和深度(第几级)
{
if( D 是一个合法的文件目录)
{
PrintName(D,Depth) ;//先序遍历,即先访问它的名字打印出来
for(遍历 D 所有的孩子 C)
ListDir(C,Depth + 1) ; //递归调用,遍历子树
}
} void ListDirectory(DirectoryOrFile D) //启动程序
{
ListDir(D,0) ;
}

后序遍历

以计算文件目录大小为例

void SizeDirectory(DirectoryOrFile D)
{
int TotalSize ; TotalSize = 0 ;
if(D 是一个合法的文件目录)
{
TotalSize = FileSize(D) ;
for(D 的每个孩子 C)
TotalSize += SizeDirectory(C) ;
} return TotalSize ;
}

二叉树

是一颗每个节点都不能由多于两个儿子的树

实现

二叉查找树:左子树关键字小于父节点,右子树关键字大于父节点

节点声明和初始化

struct TreeNode ;
typedef struct TreeNode *Poisition ;
typedef struct TreeNode *SearchTree ; SearchTree MakeEmpty(SearchTree T) ;
Position Find(ElementType X, SearchTree T) ;
Position FindMin(SearchTree T) ;
Position FinMax(SearchTree T) ;
SearchTree Insert(ElementType X, SearchTree T) ;
SearchTree Delete(ElementType X, SearchTree T) ;
ElementType Retrieve(Poisition P) ; struct TreeNode
{
ElementType Element ;
PtrToNode Left ;
PtrToNode Right ;
}

Find操作

Position Find(ElementType X, SearchTree T)
{
if(T == NULL)
return NULL ;
else if(X < T->Elements)
return Find(X,T->Left) ;
else if(X > T->Elements)
return Find(X,T->Right) ; return T ;
}

FindMin和FindMax操作

递归和非递归实现

Position FindMin(SearchTree T)
{
if(T == NULL)
return NULL ;
else if(T->Left == NULL)
return T ;
else
return FindMin(T->Left) ;
} Position FindMax(SearchTree T)
{
if(T != NULL)
while(T->Right != NULL)
T = T->Right ; return T;
}

Insert操作

SearchTree Inesert(ElementType X, SearchTree T)
{
if(T == NULL)
{
T = malloc(sizeof(struct
TreeNode)) ;
if(T == NULL)
FatalError("内存不足") ;
T->Element = X ;
T->Left = T->Right = NULL;
}
else if(X < T->Element)
T-Left = Insert(X,T->Left) ;
else if(X > T->Element)
T-Right = Insert(X,T->Right) ; return T ;
}

Delete操作

只有一个节点的情况,直接用子树顶替

由两个节点的情况,找到右子树最小的元素顶替它,并删除这颗树(这颗树肯定只有一个节点)

SearchTree Delete(Element X, SearchTree T)
{
Position TmpCell ;
if(T == NULL)
Error("未找到") ;
else if(X < T->Element)
T->left = Delete(X,T-Left) ;
else if(X > T->Element)
T->Right = Delete(X,T->Right) ;
else if(T->Left && T->Right)
{
TmpCell = FindMin(T->Right) ;
T->Element = TmpCell->Element ;
T->Right = Delete(TmpCell->Element,T->Right) ;
}
else
{
TmpCell = T ;
if(T->Left == NULL)
T = T->Right ;
if(T->Right == NULL)
T = T ->Left ;
free(TmpCell) ;
} return T ;
}

树和二叉树 -数据结构(C语言实现)的更多相关文章

  1. [数据结构 - 第6章] 树之链式二叉树(C语言实现)

    一.什么是二叉树? 1.1 定义 二叉树,是度为二的树,二叉树的每一个节点最多只有二个子节点,且两个子节点有序. 1.2 二叉树的重要特性 (1)二叉树的第 i 层上节点数最多为 2n-1: (2)高 ...

  2. 数据结构(C语言版)-第5章 树和二叉树

    5.1  树和二叉树的定义 树(Tree)是n(n≥0)个结点的有限集,它或为空树(n = 0):或为非空树,对于非空树T:(1)有且仅有一个称之为根的结点:(2)除根结点以外的其余结点可分为m(m& ...

  3. 6-11-N皇后问题-树和二叉树-第6章-《数据结构》课本源码-严蔚敏吴伟民版

    课本源码部分 第6章  树和二叉树 - N皇后问题 ——<数据结构>-严蔚敏.吴伟民版        源码使用说明  链接☛☛☛ <数据结构-C语言版>(严蔚敏,吴伟民版)课本 ...

  4. 6-9-哈夫曼树(HuffmanTree)-树和二叉树-第6章-《数据结构》课本源码-严蔚敏吴伟民版

    课本源码部分 第6章  树和二叉树 - 哈夫曼树(HuffmanTree) ——<数据结构>-严蔚敏.吴伟民版        源码使用说明  链接☛☛☛ <数据结构-C语言版> ...

  5. 【C#数据结构系列】树和二叉树

    线性结构中的数据元素是一对一的关系,树形结构是一对多的非线性结构,非常类似于自然界中的树,数据元素之间既有分支关系,又有层次关系.树形结构在现实世界中广泛存在,如家族的家谱.一个单位的行政机构组织等都 ...

  6. 数据结构( Pyhon 语言描述 ) — —第10章:树

    树的概览 树是层级式的集合 树中最顶端的节点叫做根 个或多个后继(子节点). 没有子节点的节点叫做叶子节点 拥有子节点的节点叫做内部节点 ,其子节点位于层级1,依次类推.一个空树的层级为 -1 树的术 ...

  7. 数据结构(C语言第2版)-----数组,广义表,树,图

    任何一个算法的设计取决于选定的数据结构,而算法的实现依赖于采用的存储结构. 之前线性表的数据元素都是非结构的原子类型,元素的值是不可再分的.下面学习的这两个线性表是很特殊的,其中数据元素本身也可能是一 ...

  8. Java数据结构之树和二叉树(2)

    从这里始将要继续进行Java数据结构的相关讲解,Are you ready?Let's go~~ Java中的数据结构模型可以分为一下几部分: 1.线性结构 2.树形结构 3.图形或者网状结构 接下来 ...

  9. Java数据结构之树和二叉树

    从这里开始将要进行Java数据结构的相关讲解,Are you ready?Let's go~~ Java中的数据结构模型可以分为一下几部分: 1.线性结构 2.树形结构 3.图形或者网状结构 接下来的 ...

随机推荐

  1. ARM 汇编指令集 特点5:ARM 多级指令流水线

    1.为增加处理器指令流 的速度,ARM使用多级流水线. 就是举个例子: mov r1,#0 ,这条指令 分几个人做,一个人从存储器取指令,解码指令中用到的寄存器,寄存器运算. 这样三步 :如果一个人做 ...

  2. http1.X与2.0

    HTTP HTTP 1.X HTTP是建立在TCP协议上的,HTTP协议的瓶颈及优化都是基于TCP协议本身的特性. TCP建立连接时有三次握手 会有1.5RTT的延迟,为了避免每次请求都经历握手待来的 ...

  3. GoBelieve,IMSDK android版开发环境问题

    GoBelieve,IMSDK android版开发环境问题 --- Mac下,android Studio 需要java1.7配置问题 On a mac, check your java versi ...

  4. Python 学习笔记(九)Python元组和字典(三)

    字典常用方法 copy() 返回一个字典的浅复制 示例:浅拷贝d.copy() 深拷贝引入import copy   copy.deepcopy() >>> help(dict.co ...

  5. JAVA数据类型能串门不?

    JAVA这几种数据类型,能否串门?入了人家门,就得按人家规矩来,入乡随俗哦,难免发生有自觉的 还有不情愿被动的. 自动类型转换 自动类型转换:容量小的数据类型可以自动转换为容量大的数据类型.在图中,黑 ...

  6. 利用CSS3选择器实现表格的斑马纹

    要用到的Css3选择器 element:nth-child(number){ } 选择器匹配属于其父元素的第 number 个子元素 参数 Number odd 奇数 even 偶数 W3School ...

  7. Spring Boot 多环境部署

    再简单的应用系统,通常都有两个环境——开发环境和线上环境.大型的企业应用还会有更多的环境,比如测试环境.准线上环境.演示环境等.应用的版本也可能对应了多个环境,比如1.0版本的演示环境.2.0版本的演 ...

  8. php5.4以上 mysqli 实例操作mysql 增,删,改,查

    <?php //php5.4以上 mysqli 实例操作mysql header("Content-type:text/html;charset=utf8"); $conn ...

  9. VUE通过索引值获取数据不渲染的问题

    问题:vue里面当通过索引值获取数据时,ajax数据成功返回,但是在火狐下不渲染 解决:

  10. VSCode 配置 C++

    每次换台电脑写c++,就要找配置,很是繁琐.这次自己写篇博客,记录下相关配置过程. 安装编译器 打开下面的网站 http://www.msys2.org ,下载 64 位的 MSYS2,按照主页上的步 ...