数据结构与-02 线性表 .ppt

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

第2章 线性表 2. 1 线性表的概念 1.构造空表 3.删除 4.定位 有序表归并 例:交替扫描 例:交替扫描 例:交替扫描 例:交替扫描 例:交替扫描 例:交替扫描 例:交替扫描 例:交替扫描 例:交替扫描 例:交替扫描 例:交替扫描 例:交替扫描 例:交替扫描 例:交替扫描 例:交替扫描 例:交替扫描 例:交替扫描 例:交替扫描 例:交替扫描 例:交替扫描 例:交替扫描 例:交替扫描 例:交替扫描 例:交替扫描 例:交替扫描 例:交替扫描 例:交替扫描 2. 3 线性表的链式表示和实现 2.3.1 单链表 动态分配与释放 插入(无头结点) (2)删除(无头结点) (2)删除(无头结点) 插入到第i结点前 等效插入(在*p之前) 删除第i结点 等效删除 (3) 建表(头插法) (3)建表(尾插法) (4)初始化 (5)求表长 (7)按序号查找(定位) 例 单链表求和 例 单链表清空 例 单链表清空 例 单链表逆置 例 单链表逆置 例: 链表合并? 例: 链表合并? 例:链表求并 小结 静态链表 静态链表 (1) 初始化 (2) 结点分配和回收 (3) 建表(带头结点) (4)求表长 (5) 按值查找 (6) 第i点前插入 (7) 删除第i点 例:求(A-B)∪(B-A) 2.3.2 循环链表 单循环链表 例 多项式的表示 2.3.3 双(向)链表 2.3.3 双(向)链表 双循环链表 (1) 前插 (2) 自删 (3) 初始化 (4) 求长度 (5)建表(头插法) 顺序表与链表的比较 顺序表与链表的比较 单链表是线性表的一种链式存储结构 线性链表的特点 1 通过保存直接后继元素的存储位置来表示 数据元素之间的逻辑关系; 2 插入、删除操作通过修改结点的指针实现; 3 不能随机存取元素; 静态链表(Static Linked List):通过数组下标实现的链表,由于数组空间要预先静态分配,故得名。数组空间也称存储池。 原理:定义一个结构数组,每个结点存放两个信息,一个是结点本身的数据,一个是其后继的数组下标。申请结点时,从存储池内取一结点;释放结点时,归还到存储池内。 const int MAXSIZE = 100 ; //存储池容量 typedef int ElemType ; //结点数据类型int typedef struct { ElemType data; //数据域 int cur; //指针域 }Component, SLinkList[MAXSIZE]; 静态链表(Static Linked List):通过数组下标实现的链表,由于数组空间要预先静态分配,故得名。数组空间也称存储池。 循环链表(Circular Linked List)是一种首尾相接的链表。其特点是无需增加存储量,仅对表的链接方式稍作改变,就可使表的处理更加方便灵活。 从任一结点出发可访问到其它所有结点 有时不给头指针,而给尾指针rear:  尾结点:rear  头结点:rear-next  首结点:rear-next-next 单链表中,将尾结点的指针域由NULL改为指向首结点或头结点 H an . . . a2 a3 a1 无头结点 H an . . . a1 a2 H 有头结点 rear an . . . a1 a2 尾指针形式 rear struct Lnode{ int co; //系数 int exp; //指数 struct Lnode * next; }; 只存非零系数,各系数组成链表; 每结点三部分信息:系数值、指数和后继指针 运算中首尾项可能变化,为方便起见,采用循环链表。 按值查找 LinkList locate(LinkList L,datatye x) { LinkList p; p=L-next; while(p!=L p-data!=x) p=p-next; return p; } 注意:结束条件p!=L,不是p!=NULL L a1 a2 an p … 数据域 data 指针域 prior 指针域 next 结点 存储元素值 存储后继地址 存储前趋地址 双向链表(Doubly Linked List):每个结点有两个指针域,一个指向直接后继,一个指向直接前趋。 找前趋、后继都方便 a1 ∧ a2 an ∧ an-1 L typedef int ElemType; //结点数据类型,假设为int typedef struct DuLNode { E

文档评论(0)

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

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

1亿VIP精品文档

相关文档