- 1、本文档共62页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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 =
您可能关注的文档
- 场地设计范例.pptx
- 人教版五年级下册第八单元复习(整理.pptx
- 基础知识信息论初步.pptx
- 平行登记会计学原理下要点.pptx
- 六级告别贫困奔小康.pptx
- 急性心肌梗死的危险.pptx
- 办公用品和设备管理.pptx
- 全国创新杯汽车与维修类说课大赛一等奖作品汽车中控门锁与防盗系统的检测与维修上课.pptx
- 化学九年级上册题1空气.pptx
- 建构主义与人本主义学习理论1.pptx
- 新的一年工作展望.docx
- 医生年终个人工作的述职报告(3篇).docx
- 2023年消防设施操作员之消防设备中级技能考前冲刺练习题附答案详解.docx
- 2022-2023年环境影响评价工程师之环评技术导则与标准通关练习题包括详细解答.docx
- 2023年中级注册安全工程师之安全生产管理考前冲刺检测卷和答案.docx
- 2023年中级银行从业资格之中级银行管理考前冲刺测试卷提供答案解析.docx
- 2023年公共营养师之二级营养师通关模拟考试试卷附带答案.docx
- 证券分析师之发布证券研究报告业务考前冲刺模拟题库.docx
- 2022-2023年二级建造师之二建建设工程法规及相关知识综合提升测试卷附答案.docx
- 2023年二级建造师之二建机电工程实务通关模拟考试试卷提供答案解析.docx
文档评论(0)