- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 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
您可能关注的文档
最近下载
- 2024年10月自考13005软件工程试题及答案.docx VIP
- 三角形内角和教学设计优质课一等奖.pdf VIP
- 英语四六级常见短语及词组固定搭配汇总.pdf VIP
- 2025年自考税收筹划真题答案.docx VIP
- 2024_2025学年广东省广州市黄埔区高一上学期(10月)月考数学试卷【有解析】.pdf VIP
- 2025年中国静脉注射用人免疫球蛋白数据监测研究报告.docx
- 自考树社会学概论真题及答案分析.docx VIP
- 2025-2026学年江苏省无锡市高一上学期10月月考物理模拟试卷含详解.docx VIP
- (高清版)B 3100-1993 国际单位制及其应用.pdf VIP
- 6SE70系列变频器讲解及Drive Monitor调试(内部员工培训).ppt
文档评论(0)