- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
04线性表2
节能 void inslist(int i,char x) { node *s,*p; int j; if(i1) printf(“\t\t 位置错误!\n); j=i-1; p=searchlist1(j);/*找第i结点的前趋*/ if(p==NULLi!=1) printf(“\t\t 位置错误!\n); else { s=(node*)malloc(sizeof(node)); n++; s-data=x; s-next=p-next; p-next=s; } } ④ 插入运算inslist(L,x,i) 算法思想: (1)先求出第i-1个结点 (2)然后在第i-1个结点之后插入结点x。 (5)删除运算 删除单链表中*p的后继 算法描述: DeleteA(p) /*删除*p的后继结点*r,设*r存在*/ node *p; {node*r; if(p-next!=null) r=p-next; p r p-next=r-next; free(r); } }/*enddelete*/ 思考: (1)如何删除单链表中p结点本身? (2)如何删除单链表中p结点的前趋结点? 例1-7:在单链表上实现线性表的删除运算Delete(L,i)。 思想:先找到被删结点(第i个)的前趋结点,即第i-1个结点*p,然后删除*p的后继。 删除实现 DELETE(L,i) node *L; int i; {node*p; int j; j=i-1; p=searchlist1(L,j);/*找到第i-1个结点*p*/ if ((p!=null)(p-next!=null)) DeleteA(p); else printf(“error\n”) }/*end*/ 实现删除线性表head中数据域为x的结点。 算法 1). 若链表为空,返回; 2). 查找值为x的结点及其前趋结点; 3). 将x结点删除。 实现删除线性表head中数据域为x的结点。 void dellist(char x) { node *p,*q; if(head==NULL) { printf(\t\t链表下溢!\n); return; } if(head-next==NULL) { printf(\t\t线性表为空!); return; } q=head; p=head-next; 实现删除线性表head中数据域为x的结点。(续) q=head; p=head-next; while(p!=NULLp-data!=x) { q=p; p=p-next; } if(p!=NULL) { q-next=p-next; free(p); printf(\t\t %c 已经被删除!,x); } else printf(\t\t 未找到!\n); } 2.3.3 循环链表 整个链表形成一个环,从表中任一结点出发均可找到表中其它结点。 特点:(1)表中最后一个结点的指针指向第一个结点或表头结点(如有表头结点的话)。 h …….. (非空表) h (空表) (2)循环链表的运算与线性链表基本一致。但两者判断是否到表尾的条件不同: 线性表:判断某结点的链域是否为空。 循环链表:判断某结点的链域值是否等于头指针。 (3)用头指针表示的单循环链表查找结点: 找a1(开始结点) O(1) 找an 需要遍历表 O(n) 由于在实际问题中,对表的操作常在表的首尾位置进行,因此可增加一个尾指针(rear),则: 找a1(开始结点) :rear-next-next O(1) 找an rear O(1) 实用中多用尾指针表示单循环链表。 [例] 表的合并: 在链表上实现将两个线性表(a1,a2,…..,an)和(b1,b2…bm)链接成一个线性表(a1,a2,….,an,b1,b2,….,bm)的运算。 node *CONNECT(ra,rb) node *ra,*rb; {node*p; p=ra-next;/*保存链表ra的头结点地址*/ ra-next=rb-next-next;
您可能关注的文档
最近下载
- 新疆某铜矿选矿工艺流程研究.pdf VIP
- 2025年部编人教版五年级《道德与法治》上册教案(全册) .pdf VIP
- 1989年高考语文试题全国卷.docx VIP
- 心脏MR临床应用.pptx
- 2025中级消防设施操作员作业考试题及答案(1000题).doc
- 摩登家庭台词剧本第一季第一集中英双语左右对照.pdf VIP
- 2018年钢铁-环保技术培训.pdf VIP
- 高中英语人教版选择性必修第一册词汇表单词英译汉默写.docx VIP
- 第三课 我国的经济发展 课件-2025年高考政治一轮复习必修二《经济与社会》.ppt.pptx VIP
- 附件2广东电网有限责任公司配电网规划技术指导原则.pdf VIP
文档评论(0)