




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
第二章机械CAD/CAM常用的数据结构第一节基本概念一、数据和数据结构
数据
是一切描述客观事物并能被计算机接受和处理的符号的集合。数据结构
是描述物体数据元素之间关系的组织形式。具有8各顶点的图形数据结构数据结构包含的内容数据结构一般包含着三个内容:1)数据的逻辑结构,既数据元素之间的逻辑关系。2)数据的物理结构,既数据元素及其关系在计算机中的存储表示。3)数据的运算,即对数据进行的各种操作。二、数据的逻辑结构和物理结构数据的逻辑结构是从解决问题的需要出发,为实现必要的功能所建立起来的数据关系,是面向问题的,它的结构形式与存储形式无关。
汽车组成的逻辑结构图
数据的物理结构数据的物理结构是数据在计算机中的存储形式,是面向计算机的。物理结构根据问题所要求的响应速度、处理时间、修改时间、存储空间和单位时间的处理量等建立,是逻辑数据在计算机中的存储映像。同一逻辑结构的数据可以映像出多种物理结构形式。以数组构成的树型物理结构三、数据项、记录、数据文件数据项描述对象性质的数值和字符统称为属性值。数据结构中把描述属性的数据称为数据项(也称为字段),数据项是构成数据的最小单位。记录数据结构中把描述一个对象的数据称为记录(也称为数据元素、结点),记录是组成数据的基本单位。记录是相对的数据文件若干个记录组成的数据表称为数据文件。数据的逻辑结构分为两大类线性结构的特征是所有结点最多只有一个直接前驱结点和一个直接后继结点。非线性结构的特征是一个结点可以有多个直接前驱的结点(如网状结构)和多个后继结点(如树状结构和网状结构)。第二节线性表一、线性表的定义线性结构中的所有结点按前驱后继关系可以排成是一个线性序列:(a1,a2,a3,…,ai,…,an)这个序列称为线性表。线性表的存储结构分类1)顺序存储结构2)非顺序存储结构二、线性表的顺序存储结构线性表的顺序存储就是用一组连续的存储单元按线性表数据元素的逻辑结构依次存放表中所有数据元素。知道前一个元素的地址和元素所占用的空间,也就知道它下一个或上一个元素的地址线性顺序表的基本运算插入删除线性表的特点1)一般是静态表2)插入删除操作时间长3)存储,读入方便三、线性表的链式存储结构
链表链表的存储单元可以是连续的,也可以是不连续的,不连续的链表存储单元可以通过指针来实现线性表中各数据元素之间的逻辑关系。特点不需要事先知道一张表的长度增删操作方便等优点
1.单向链表
节点定义typedefstructlinknode{ElemTypedata;structlinknode*link;}node;1)建立一个单向链表。2)遍历单向链表3)查找接点4)插入接点5)删除接点单向链表不能反向查询和操作2。双向链表定义建立遍历插入删除应用第三节栈、队列和数组一、栈
表中结点的插入、删除运算只能在表的一端进行栈的定义typedefstruct{ElemTypes[m0];Inttop;}stack;1.栈的压入
viodpush(ST,x)stack*ST;intx;{if(ST->top==m0)printf(“栈上溢出!\n”);else{ST->top=ST->top+1;ST->s[ST->top]=x;}}2.栈的弹出
voidpop(ST)stack*ST;{if(ST->top==0)printf(“栈下溢出!\n”);/*若栈空则显示相应信息*/
elseST->top--;/*否则栈指针减1,即栈顶为下一个元素*/}3.读栈顶元素4.判断栈是否为空二、队列它只允许在表的一端进行插入,而在另一端删除(先进先出)
第四节树结构树是n(n>0)个结点的有限集合T。在一棵树中要满足两个条件:1)有且仅有一个特定的称为根(root)的结点。2)其余的结点可分为m(m≥0)棵互不相交的有限集合T1,T2,…,Tn,其中每一个集合又都是一棵树,称其为根的子树(subtree)。一般树概念根
子树
度一个结点具有的子树数目称为该结点的度
结点A、B、C的度分别为2、3、1树的度为3
叶子结点或终端结点层次
二、二叉树它的特点是每个结点下只有左右两棵子树,且左右子树不能颠倒,否则为另一棵二叉树。二叉树有五种基本形态,如图2-20所示,其中(a)空二叉树,(b)只有一个根结点的二叉树,(c)右子树为空的二叉树,(d)左子树为空的二叉树,(e)左右子树均为非空的二叉树。二叉树与一般树的区别在于:
1)一般树至少有一个结点,而二叉树可以为空。2)一般树的子树不区分其次序,而二叉树有左右之分,且不能颠倒。3)一般树的每一个结点可以有任意个子树,而二叉树每一个结点的子树不能超过2个。应用三、二叉树的遍历
按一定的次序访问二叉树的每一个结点,且每个结点仅访问一次称为二叉树的遍历,对于图2-21所示的二叉树,按三种遍历的结果分别为:1)先序遍历(DLR)的结果:A、B、C、D、E、F、G、H、I。2)中序遍历(LDR)的结果:C、D、B、E、A、H、G、F、I。3)后序遍历(LRD)的结果:D、C、E、B、H、G、I、F、A。定义TypeLink=^data;Data=recordData1:integer;Left,right:link;End;先序遍历Procedurepreorder(p:link);Beginif(p!=Nil)thenbeginwriteln(p^.data1);preorder(p^.left);preorder(P^.right);end;End;中序遍历:Procedureinorder(p:link);Beginif(p<>Nil)thenbeginintorder(P^.left);writeln(p^.data1);inorder(p^.right);end;
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年甘肃工业职业技术学院单招职业适应性测试题库完美版
- 科技助力提高眼科诊疗效率
- 科技创新助力医疗健康文化的传播与发展
- 2025年硅湖职业技术学院单招职业技能测试题库带答案
- 2025年广西物流职业技术学院单招职业倾向性测试题库及答案一套
- 2025年黑龙江旅游职业技术学院单招职业适应性测试题库汇编
- 2025年广西英华国际职业学院单招职业技能测试题库学生专用
- 眼科医疗技术国际交流与合作
- 2025年安全员考试题库
- 品牌塑造与管理练习卷含答案
- 2024年华师大版九年级数学下册全册教案
- 合肥市庐阳区双岗街道社区工作者招聘考试试题及答案2024
- JBT 106-2024 阀门的标志和涂装(正式版)
- 煤矿技术员必须会的知识
- (高清版)JTGT 3650-01-2022 公路桥梁施工监控技术规程
- 2024年黑龙江建筑职业技术学院单招职业适应性测试题库全面
- 北京市2024小升初数学模拟试卷一
- 一年级口算题100以内比大小
- 《提案与方案优化设计》课件-第一部分 常见户型问题解析及平面布局优化
- 《水电厂应急预案编制导则》
- 产科抗磷脂综合征诊断与处理专家共识
评论
0/150
提交评论