- 1、本文档共35页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数据结构—chapter1_绪论
教材及参考书目;学习数据结构的意义;学习这门课程的目的;教 学 内 容;数据结构课程的特点及学习方法;第 一 次 课;Chapter 1 绪论;1.1 基本术语;
例、图书自动检索系统的数据
;● 数据结构(Data Structure)
◆ 元素之间的关系称为结构。数据结构,简单地说,就是数据元素的集合加上数据元素之间的相互关系的集合,可形式化地描述成一个二元组:
Data Structure=(D,S)
其中,D:数据元素的集合,
S:D上关系的集合。
◆ 1968年唐?欧?克努特[美]:
;◆ 数据的逻辑结构
数据元素之间抽象化的相互关系。二元组形式化定义中的S即指的逻辑结构。
三类基本结构: 线性结构
树形结构
图形结构
也可简单分为:
线性结构:线性表、栈、队列、 串、 数组
非线性结构:树、二叉树、图
;
例1、图书自动检索系统(建立、查找、插入/删除)
;例2、一个大学的人事档案处理系统
学校
一院(系) 二院(系) … n院(系)
一专业 二专业 … m专业
教师 学生
档案 档案…档案 ;例3、交通管理信息系统;◆ 数据的物理结构(存储结构)
逻辑结构到计算机存储器的映象。
映象方法: 顺序分配
链式分配;◆ 数据的运算(操作)
逻辑操作 和 具体操作 :
逻辑结构
逻辑操作
存储结构
具体操作
常用的逻辑操作有:
(1)建立一个数据结构
(2)销毁一个数据结构
(3)插入一个新元素到一个指定的数据结构
(4)删除一个元素
(5)修改一个元素(或其中的数据项)的内容
(6)排序
(7)查找
;概念小结;● 数据类型(Data Type)
数据类型是一组值的集合以及定义在这个值集上的一组操作的总称。通常可看作是高级程序设计语言中已实现的数据结构。
例:C语言中的“整型”变量。;● 抽象数据类型(Abstract Data Type, Abbr. ADT)
是指一个数学模型以及定义在该模型上的一组操作,可以看作是数据的逻辑结构及其在逻辑结构上定义的操作。
对一个ADT必须经过定义和实现之后才能使用。
定义包含三部分:
数据元素
数据元素之间的相互关系(结构)
定义在数据结构上的一组操作;例、线性表抽象数据类型的定义:
ADT List
数据元素: ai是整数,i=0,1,…,n-1 (n≥0)
结构:对所有的数据元素ai ( i=0,1,…,n-2 )存在次序关系 ai, ai+1, a0无前趋,an-1无后继。
操作:设L为 List 型的线性表
ListInitiate(L) //构造一个空的线性表L。
ListLength(L) //返回线性表L中的元素个数,即求表长。
ListInsert(L,i,x) //在线性表L的第i个位置前插入一个值 为x 的新元素,插入成功返回1,失败返回0。 0≤i≤n,插入后表L的长度为n
文档评论(0)