利用链结串列.pptxVIP

  1. 1、本文档共62页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Data Structure in C ─ 鏈結串列;1;2;3;4;5;6;Step 1: x = (struct node *) malloc(sizeof(struct node)); x-next = NULL;;Step 3: head = x;;Step 2: tail-next = x;;Step 1: x = (struct node *) malloc(sizeof(struct node)); x-next = NULL;;Step 3: ptr-next = x;;void insert_node(struct node *ptr, struct node *head, struct node *tail) { struct node *this if(head == NULL) /* 插入資料為第一筆 */ { ptr-next=NULL; head=ptr; tail=ptr;} else { this=head; if(ptr-key this-key) /* 插入位置為前端 */ { ptr-next=this; head=ptr; } ; else {while(this-next != NULL) { prev=this; this=this-next; if(ptr-key this-key) /* 插入位置於中間 */ { ptr-next=this; prev-next=ptr; break; } } if(ptr-key = this-score) /* 插入資料於尾端 */ { ptr-next=NULL; this-next=ptr; tail=ptr; } } } };14;Step 1: ptr = head;;刪除串列尾端的節點;刪除串列某一特定節點;Step 2: prev-next = this-next;;void delete_f(int del_key, struct node *head, struct node *tail) { struct node *clear, *this, *prev; this=head; if(del_key == head-key) { /* 刪除資料於前端 */ clear=this; if(head-next == NULL) /* 資料僅存在一筆 */ tail=NULL; head=head-next; free(clear); } while(this-next != NULL) { /* 刪除資料於中間 */ prev=this; this=this-next; if (del_key == this-key) { clear=this; prev-next=this-next; free(clear); } } if(del_key == tail-key) { /*刪除資料於尾端 */ clear=this; prev-next=NULL; tail=prev; free(clear); };20;void concatenate (struct node *x, struct node *y, struct node *y) { struct node *c; if (x = = NULL) z = y; else if (y = = NULL) z = x; else { z=x; c=x; while(c-next != NULL) c = c-next; c-next = y; } };將一串列反轉 串列的反轉是將原先的串列首變成串列尾 Ex. 若一串列原先以小排到大,此時若想由大到小排列 void invert(struct node *head) { struct node *this, *prev, *next_n; next_n = head; this =NULL; while(next_n != NULL){ prev = this; this = next_n; next_n =

文档评论(0)

118zhuanqian + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档