- 1、本文档共47页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
期末复习(数据结构).doc
数据结构期末复习
__________________________by 大剑
、绪论
程序设计:为计算机处理问题编制一组指令集
算法:处理问题的策略
数据结构:问题的数学模型
数据(Data):是对信息的一种符号表示。在计算机科学中是指所有能输入到计算机中并被计算机程序处理的符号的总称。
数值性数据
非数值性数据
数据元素(Data Element):是数据的基本单位,在计算机程序中通常作为一个整体进行考虑和处理。
数据项(Data Item):数据的不可分割的最小单位,一个数据元素可以由若干个数据项构成。
数据对象(Data Object):性质相同的数据元素的集合,是数据的一个子集。
整数数据对象 N = { 0, ?1, ?2, … }
学生数据对象
数据结构(Data Structure):相互间存在一种或多种特定关系的数据元素的集合
4种基本结构:
集合:数据元素除了同属一个集合,没有别的关系
线性结构:数据元素间是一对一的关系
树形结构:数据元素间是一对多的关系
图状或网状结构数据元素间是多对多的关系
数据结构数学定义:数据结构是一个二元组
Data_Structure = (D,S)D – 数据元素的有限集合S – 定义在D上的关系的有限集合
逻辑结构和物理结构
逻辑结构:数据元素之间的逻辑关系
物理结构:数据结构在计算机中的表示,又称存储结构
算法的设计取决于选定的逻辑结构
物理结构
顺序存储结构:把数据元素存放在地址连续的存储单元里,其数据间的逻辑关系和物理关系是一致的。
链式存储结构:把数据元素存放在任意的存储单元里,这组存储单元可以是连续的,也可以是不连续的。
数据类型:数据类型是一组性质相同的值的集合, 以及定义于这个值集合上的一组操作的总称。
数据类型的作用是:明确地或隐含地规定了在程序执行期间变量、表达式或函数所有可能取值的范围,以及作用在这些取值上的操作。
数据类型的分类:
基本数据类型
构造数据类型
抽象数据类型(ADT, Abstract Data Types):一个数学模型以及定义在该模型上的一组操作。
ADT有两个重要特征:1、数据抽象 2、数据封装
算法和算法分析
算法定义:对特定问题求解步骤的一种描述.
算法的特征
有穷性
确定性:不产生二义性,并且在任何条件下,算法都只有一条执行路径;
可行性:算法中描述的操作都可以通过已经实现的基本运算执行有限次来实现;
输入:有零个或多个输入;
输出:有一个或多个输出。
算法设计原则:
正确性
可读性
健壮性
高效性与低存储量
运行该算法所需要的计算机资源,包括时间资源与空间(存储器)资源
空间复杂度
需要空间资源的量
S(n) = O(f(n))
时间复杂度
需要时间资源的量
T(n) = O(f(n))
指针、结构体
指针变量:用来存放地址的变量。
取地址运算符
用法:变量名
功能:取变量的地址
单目运算符,“右”结合性,优先级2
指针变量的定义:
类型名 *指针变量名;
指针变量的赋值:
结构体:由不同类型的数据(成员变量)构成,各自占有独立的内存空间。
如果需要把一个学生的学号、姓名、性别、年龄、各门功课的考试成绩等不同类型的数据放在一个构造型数据类型中,就需要结构类型或者联合类型。
一个结构类型的变量中可以独立存放多种类型的数据。
、线性表
线性表(linear_-list)是最常用且最简单的一种数据结构。
线性结构的特点
存在唯一的”第一个”数据元素
存在唯一的”最后一个”数据元素
除第一个外,每个数据元素均有且只有一个前驱元素
除最后一个外,每个数据元素均有且只有一个后继元素。
定义:线性表L是n(n=0)个相同类型数据元素a1, …, an-1, an构成的有限序列。表示成L=(a1,… ,an-1,an)
n个元素的线性表:
(a1, a2 ,…, ai, ai+1, …, an) a1第一个元素(没有前驱) ai 第i个元素(有唯一的前驱和唯一的后继) an 最后一个元素(没有后继)
线性表举例:
字母表 (A,B,C,…,X,Y,Z)
数据序列 (6,17,28,50,92,188)
线性表的链式表示与实现
顺序表示的优点是随机存取表中的任意元素
顺序表示的弱点是在作插入或删除操作时,需移动大量元素
链式表示没有顺序表示的弱点,也失去了顺序表示的优点。
线性链表
建立单链表:逆位序输入n个元素,建立带表头结点的单链表L
void CreateList_L( LinkList L , int n )
{ LinkList p;
L = (LinkList)ma
文档评论(0)