数据结构与算法分析(C语言)——树

本文探讨了树这种数据结构在操作系统文件系统和计算算术表达式中的应用,并深入讲解了树的定义、高度计算以及在支持O(logN)操作中的角色。特别提到了二叉树的结构及其在编译器设计中的应用,包括查找、插入和删除操作。此外,还提及了AVL树作为带平衡条件的二叉查找树的概念。
摘要由CSDN通过智能技术生成

树是一种数据结构:其作用是在大量的数据输入时较少访问时间(相对于链表的线性访问),它的平均操作时间位O(logN)。
主要问题为
1.树在操作系统中的文件系统中的如何应用?
2.树在计算算数表达式的值?
3.如何利用树在支持以O(logN)平均时间进行的各种操作,以及如何得到最坏时间界O(logN)?
①树的第一种定义方式是——自然递归
存在N个节点,N-1条边。
同时,在一棵树中从根到每个节点恰好存在一条路径。根的深度为0,没有下一个节点连接的节点被称作叶,叶的高度为0,n1的高是从n1到一片树叶的最长距离,E的深度为1而高为2,F的深度为1而高为1,该树的高为3,而树的深度总等于这棵树的高。
在这里插入图片描述
②UNIX文件系统不是树,而是类树
③二叉树
一棵二叉树最多有两个儿子,可以用指针指向它们,树节点的声明在结构上类似于双链表的声明。
主要应用之一编译器的设计领域在这里插入图片描述④查找ADT——二叉查找树
⑤MarkEmpty
⑥Find
⑦FindMin和FindMax
⑧Insrt
⑨Delete
如果删除的次数不多,则使用的惰性编程——不删除只做一个删除标记。
AVL树
是带有平衡条件的二叉查找树。左右

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值