网站大量收购独家精品文档,联系QQ:2885784924

算法与数据结构_张晨光_第2章1.ppt

  1. 1、本文档共91页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
算法与数据结构_张晨光_第2章1

第二章 线性表 线性结构 在数据元素的非空的有限集合中: 存在唯一的一个被称为“第一个”的数据元素; 存在唯一的一个被称为“最后一个”的数据元素; 除第一个元素外,集合中每个元素都有且仅有一个前驱; 除最后一个元素外,集合中每个元素都有且仅有一个后继; 线性表(Linear List)定义 定义: n个具有相同特性的数据元素组成的有限序列; 表示:{a1,…,ai-1,ai,ai+1,…,an} ai必须具有相同特性,即属于同一数据对象 ai-1是ai的直接前驱元素,ai+1是ai的直接后继元素 数据元素ai在线性表中有确定的位置i,i称为位序 线性表中数据元素的个数n称为线性表的长度,n=0时,线性表称为空表 抽象数据类型定义 ADT LinearList { 数据对象:D={ai|ai∈ElemSet,i=1,2,…,n,n≥0} 数据关系:R={ai-1,ai|ai,ai-1∈D,i=2,…,n} 基本操作: virtual int Length() const = 0; //求表长度 virtual int Search(T x) const = 0; //搜索 virtual E* getData(int i) const = 0; //取值 virtual void setData(int i, E x) = 0; //赋值 virtual bool Insert(int i, E x) = 0; //插入 virtual bool Remove(int i, E x) = 0; //删除 virtual bool IsEmpty() const = 0; //判表空 virtual bool IsFull() const = 0; //判表满 }ADT LinearList 线性表举例1(遍历线性表) ListTraverse(LinearList L,visit()) {//遍历线性表 if(L. IsEmpty()) printf(“空表”); else for(i=1;i=L.Length();i++) visit(L.getData(i) ); } 线性表举例2(合并线性表) LinearList ListMerge(LinearList La,LinearList Lb) {//La和Lb是两个非递减有序的线性表,将线性表La和Lb合并成一个新的线性表Lc,Lc也非递减有序。 LinearList Lc i=j=1;k=0; La_len=La.Length();Lb_len=Lb.Length(); while((i=La_len)(j=Lb_len))//La和Lb均非空 {ai=La.getData(i); bj=Lb.getData(j); if(ai=bj){Lc.Insert(++k,ai);++i;} else {Lc.Insert(++k,bj);++j;} } 线性表举例2(合并线性表) 逻辑结构是本质 通过上面两个例子可以看出: 逻辑结构是数据组织的某种“本质性”的东西: (1)逻辑结构与数据元素本身的形式、内容无关。 (2)逻辑结构与数据元素的相对位置无关。 (3)逻辑结构与所含数据元素的个数无关。 算法的设计取决于选定的逻辑结构,而算法的实现依赖于采用的存储结构 线性表的顺序表示和实现 线性表的顺序表示 :线性表的顺序存储是指在内存中用地址连续的一块存储空间顺序存放线性表的各元素,用这种存储形式存储的线性表称为顺序表。 设 a1的存储地址为Locate(a1),每个数据元素占L个存储单元,则第i个数据元素的地址为: Locate(ai)=Locate(a1)+(i-1)*L 1≤i≤n 顺序存储结构的线性表的类型定义如下: #define maxSize 100 typedef int T; typedef struct { T data[maxSize]; //顺序表的静态存储表示 int n; } SeqList; 或者: typedef int T; typedef struct { T *data; //顺序表的动态存储表示 int maxSize, n; } SeqList; 顺序表(SeqList)类的定义 #include iostream.h //定义

文档评论(0)

wyjy + 关注
实名认证
内容提供者

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

1亿VIP精品文档

相关文档