- 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
* 单链表: typedef struct Lnode { ElemType data; struct LNode *next; } Lnode,*LinkList; 另一种实现链表的方法是使用一维数组实现静态链表。 静态链表 结构: #define MAXSIZE 1000 100 Typedef struct { Elemtype data; int cur; }component,SLinkList[MAXSIZE ]; * * 静态链表 S[0].cur:指示第一个结点在数组中的位置; 若i= S[0].cur ,则: S[i].data存储线性表的第一个元素; S[i].cur存储第二个结点在数组中的位置 * * 例: 数组下标 数据 指针 0 头结点 3 1 赵明 0 2 3 张红 5 4 5 黎明 1 Head 黎明 赵明 ∧ 张红 * * 0 1 1 张斌 2 2 刘丽 3 3 李英 4 4 陈华 5 5 王奇 6 6 董强 7 7 王萍 0 8 9 下标 数据 next 0 1 1 张斌 2 2 刘丽 3 3 李英 5 4 陈华 5 5 王奇 6 6 董强 7 7 王萍 0 8 9 下标 数据 next 删除陈华 * * 0 1 1 张斌 2 2 刘丽 3 3 李英 4 4 陈华 5 5 王奇 6 6 董强 7 7 王萍 0 8 9 0 1 1 张斌 2 2 刘丽 8 3 李英 5 4 5 王奇 6 6 董强 7 7 王萍 0 8 王芳 3 9 在“刘丽”之后插入“王芳”: 在刘丽的后面插入王芳: * * 静态存储结构与顺序存储结构的比较: 不同点: 插入和删除操作不需要移动元素 仅需要修改cur值 相同点: 都需要预先分配一个较大的存储空间 * * 定义:最后一个结点的指针指向头结点,使链表构成环状。 循环链表是表是另一种形式的链式存储结构; 特点:从表中任一结点出发均可找到表中其他结点,查找效率高。 循环链表 H a1 ai-1 an ∧ ai p * * 循环链表 将单链表的首尾相接,将终端结点的指针域由空指针改为指向头结点,构成单循环链表,简称循环链表。 H a1 ai-1 an ∧ ai p * * 循环链表 空表和非空表的处理一致 附设头结点 H 空循环链表 H a1 ai-1 an ai 非空循环链表 * * 循环链表 a1 a2 … an head 判断空表的条件是: head head-next= =Head 判断结点P为表尾条件: P-next= =Head * * 单链表具有单向性的缺点,查找不方便。 prior 结点结构: 带头结点的非空双向链表: 双向链表 Next * * b c a p 结点定义 typedef struct DuLNode { Elemtype data; struct DuLNode *prior; struct DuLNode *next; } DuLNode, *DuLinkList; p-prior-next= p= p-next-proir 双向链表 * * 结点删除 结点插入 双向链表的运算 * * b c p-prior-next=p-next; p-next-prior=p-prior; 删除操作 a p * * 算法描述 Status ListDelete_Dul(DuLinkList L,int i, ElemType e) { //删除带头结点的双向链表L中第i个元素 if(!(p=GetElemP_Dul(L,i))) //在L中确定第i个元素位置 return ERROR; e = p-data; p-prior-next = p-next; p-next-prior = p-prior; free(p); return OK; } * * 插入操作算法描述: 在指针p所指结点之前插入指针s所指结点: * s-prior = p-prior; p-prior-next = s; s-next = p; p-prior=s; * 双向循环链表 * * 链式存储结构的特点 优点: 可动态申请和释放空间,不需设定最大存储空间 插入和删除操作方便 缺点: 每个结点的指针域需要另外加存储空间 链式存储是一种非随机存储结构,对于任意结点的操作都要首先从开始指针顺链查找该结点,增加了一些操作的算法时间复杂度 * * 练 习 设L为带头结点的单链表,表中元素值递增有序,编写算法删除表中相同的多余元素。 输出单链表元素值并进行计数。 * 免疫进化理论 焦
您可能关注的文档
最近下载
- 工程设计服务方案.doc VIP
- 【某工业厂房及管理楼水电安装施工方案】.doc
- 国家标准GB_T13306-2011标牌.pptx VIP
- 部编版九年级上册语文第1-3单元综合测试卷(含答案).doc VIP
- 夜袭 (5-6人封闭)剧本杀全套剧本.docx VIP
- 《少年中国说》原文及翻译 .pdf VIP
- 新食品原料β-羟基-β-甲基丁酸钙.docx VIP
- 高中英语_选择性必修二 Unit 3 Understanding Ideas A New Chapter教学课件设计.ppt
- The_Very_Hungry_Caterpillar.ppt VIP
- 《医学心理学》第2章 心理学基础-教学课件(非AI生成).ppt
文档评论(0)