- 1
- 0
- 约3.57万字
- 约 49页
- 2021-10-19 发布于江苏
- 举报
专题九:数据结构知识
———————————————————————————————— 作者:
———————————————————————————————— 日期:
专题九:数据构造知识
数据构造是计算机软件的一门根底课程,计算机科学各个领域及有关的应用软件都要用到各种数据构造.语言编译要使用栈、散列表及语法树;操作系统中用队列、存储管理表及目录树等;数据库系统运用线性表、多链表及索引树等进展数据管理;而在人工智能领域,依求解问题性质的差异将涉及到各种不同的数据构造,如广义表、集合、搜索树及各种有向图等等。学习数据构造目的是要熟悉一些最常用的数据构造,明确数据构造内在的逻辑关系,知道它们在计算机中的存储表示,并结合各种典型应用说明它们在进展各种操作时的动态性质及实际的执行算法,进一步提高软件计和编程水平。通过对不同存储构造和相应算法的比照,增强我们根据求解问题的性质选择合理的数据构造,并将问题求解算法的空间、时间及复杂性控制在一定范围的能力。
软件设计师考试大纲对数据构造局部的要求是熟练掌握常用数据构造和常用算法,因此,本专题从数据构造的概述出发,对根本的概念引出常用的数据构造类型的介绍和讲解,同时在讲解各种数据构造中间采用算法与数据构造相结合的方式,在算法步骤中使用数据构造,对数据构造的重点、难点进展了分析,最后讲解了与数据构造严密相关的排序和查找算法,以及一些以往考试题的分析。
1. 数据构造概述
数据构造研究了计算机需要处理的数据对象和对象之间的关系;刻画了应用中涉及到的数据的逻辑组织;也描述了数据在计算机中如何存储、传送、转换。
学习数据构造注意的问题:
?????????? 系统掌握根本数据构造的特点及其不同实现。
?????????? 了解并掌握各种数据构造上主要操作的实现及其性能〔时间、空间〕的分析。
?????????? 掌握各种数据构造的使用特性,在算法设计中能够进展选择。
?????????? 掌握常用的递归、回溯、迭代、递推等方法的设计
?????????? 掌握自顶向下、逐步求精的程序设计方法。
?????????? 掌握自顶向下、逐步求精的程序设计方法。
在学习数据构造的知识之前,我们要了解一下数据构造中的根本概念。
数据:对客观事物的符号表示,在计算机中就是指所有能输入到计算机中并被计算机程序所处理的符号的总称。
数据项:? 是数据的不可分割的最小单位;
数据元素:是数据的根本单位,在计算机程序中通常作为一个整体进展处理;一个数据元素可由假设干个数据项组成。
数据对象:是性质一样的数据元素的集合,是数据的一个子集。
数据构造上的根本操作:
◆插入操作 ◆删除操作 ◆更新操作 ◆查找操作 ◆排序操作
数据构造是指数据对象及相互关系和构造方法,一个数据构造B形式上可以用一个二元组表示为B=〔A,R〕。其中,A是数据构造中的数据〔称为结点〕的非空有限集合,R是定义在A上的关系的非空有限集合。
根据数据元素之间的关系的不同特性,通常有以下4类根本构造。
????????? 集合——构造中的数据元素除了“同属于一个集合〞的关系外,别无其他关系。
????????? 线性构造——构造中的数据元素之间存在一个对一个的关系。
????????? 树形构造——构造中的元素之间存在一个对多个的关系。
????????? 图状构造或网状构造——构造中的元素之间存在多个对多个的关系。
数据构造中,结点与结点间的相互关系是数据的逻辑构造。数据构造在计算机中的表示〔又称为映象〕称为数据的物理构造,也称存储构造。
数据元素之间的关系在计算机中有两种不同的表示方式:顺序映象和非顺序映象,并由此得到两种不同的存储构造:顺序存储构造和链式存储构造。
任何一个算法的设计取决于选定的数据〔逻辑〕构造,而算法的实现依赖于采用的存储构造。
数据的逻辑构造分为两类:
??? 线性构造:线性表、栈、队列和串
??? 非线性构造:树、图
数据的存储方法有四类:
???? ?顺序存储方法
??? ??链接存储方法
???? ?索引存储方法
??? ??散列存储方法
2. 常用数据构造
? ?在数据构造中,线性构造常称为线性表,是最简单、最常用的一种数据构造,它是由n个一样数据类型的结点组成的有限序列。
其特点是:在数据元素的非空有限集合中,
??????? ◆存在唯一的一个被称做“第一个〞的数据元素
??????? ◆存在唯一的一个被称做“最后一个〞的元素数据元素
??????? ◆除第一个之外,集合中的每个数据元素均只有一个前驱
??????? ◆除最后一个之外,集合中每个数据元素均只有一个后继
??? 一个由n个结点e0,e1…,en-1组成的线性表记为:〔e0,e1…,en-1〕。线性表的结点个数称为线性表的
原创力文档

文档评论(0)