数据结构与C++算法设计案例教程赖俊峰第五章课件教学.pptVIP

数据结构与C++算法设计案例教程赖俊峰第五章课件教学.ppt

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数据结构与C++算法设计案例教程赖俊峰第五章课件教学.ppt

模块五 数组、串和广义表 任务一 数组 任务二 串 任务三 广义表 任务一 数组 子任务1 数组的定义 子任务2 数组的基本操作 子任务3 特殊矩阵的压缩存储 子任务1 数组的定义 在早期的高级语言中,数组是唯一可供使用的数据类型。由于数组中各元素具有统一的类型,并且数组元素的下标一般具有固定的上界和下界,因此,数组的处理比其它复杂的结构更为简单。 数组作为一种数据结构,其特点是结构中的元素本身可以是具有某种结构的数据,但属于同一数据类型, 一维数组可以看作一个线性表,二维数组可以看作“数据元素是一维数组”的一维数组,三维数组可以看作“数据元素是二维数组”的一维数组,以此类推。如图5-1表示一个m行n列的二维数组。 图5-1中的A数组可看成是由m个行向量或者n个列向量组成的线性表。 对于上述二维数组A,这里可以将A看成是下述线性表 A =(d1,d2,…,dn) 其中每一个数据元素dj本身也是一个线性表 dj=(d1j,d2j,…,dmj) 1≤j≤n。 该线性表是二维数组A的第j个列向量。 同样,也可将二维数组A看成线性表A‘’ =(s1,s2,…,sm),其中每个si本身也是一个线性表si=(si1,si2,…,sin) 1≤i≤m,si是二维数组A的第i个行向量。 类似地,一个三维数组可以看成是数据元素为二维数组的线性表。一般地,一个n维数组可视为其数据元素为n-1维数组的线性表。 二维数组中每个元素ai,j均属于两个向量,第i行的行向量和第j列的列向量。因此,除边界外,每个元素ai,j都恰好有两个直接前趋和直接后继:行向量上的直接前趋ai,j-1和直接后继ai,j+1,列向量上的直接前趋ai-1,j和直接后继ai+1,j; 二维数组中有且仅有一个开始结点a11,它没有直接前趋;有且仅有一个终端结点amn,它没有直接后继; 边界上的结点(开始结点和终端结点除外)只有一个直接前趋或者只有一个直接后继。即除开始结点a11外,第一行和第一列上的结点a1j(j=2,...,n),ai1(i=2,...,m)都只有一个直接前趋;除终端结点amn外,第m行和第n列上的结点amj(j=1,...,n-1),ain(i=1,...,m-1)都只有一个直接后继。 数组一旦被定义,它的维数和维界就不再改变。因此,除了结构的初始化和销毁之外,数组只有存取元素和修改元素值的操作。 数组通常只有两种基本运算——读和写。 ①读:给定一组下标,读取相应的数据元素。 ②写:给定一组下标,修改相应的数据元素。 数组上的基本操作有: (1) 数组的输入:ArInput () 初始条件:数组存在。 操作结果:向数组元素中输入元素。 (2) 求数组的长度:ArLength () 初始条件:数组存在。 操作结果:显示数组中有效元素的个数。 (3) 取数组元素:ArGetElem(int n) 初始条件:数组存在。 操作结果:显示数组指定元素,如果没有则显示空。 (4) 按值查找:ArLocateElem(int m),m是给定的一个数据元素 初始条件:数组存在。 操作结果:显示m所在的位置,如果没有则显示空。 (5) 地址操作:ArAddress(int i) 初始条件:数组存在。 操作结果:显示第i号元素的地址 (6) 插入操作:ArInsertElem(int i,int j,int k,char*e) 初始条件:数组存在 。 操作结果:在第i个的第j个的第k个位置插入元素e。 (7) 删除操作:void ArDeleteElem(int i,int j,int k) 初始条件:数组存在。 操作结果:在第i个的第j个的第k个位置插入元素。 二维数组的两种存储方式 一种是以列序为主序的存储方式 一种是以行序为主序的存储方式 (a)列序为主序: a11 a21 ...am1 a12 a22 ...Am2 ... a1n a2n ...amn (b)行序为主序: a11 a12 ...a1n a21 a22 ...A2n ... am1 am2 ...amn 以上规则可以推广到多维数组的情况:优先顺序可规定为先排最右的下标,从右到左,最后排最左下标:列优先顺序与此相反,先排最左下标,从左向右,最后排最右下标。 按上述两种方式顺序存储的数组,只要知道开始结点的存放地址(即基地址),维数和每维的上、下界,以及每个数组元素所占用的单元数,就可以将数组元素的存放地址表示为其下标的线性函数。 因此,数组中的任一元素可

文档评论(0)

带头大哥 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档