- 1、本文档共46页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
(1)从可利用栈取得一个结点,设该结点号为p。 并置结点p的数据域为插入的元素值b,即V(p)=b。 (2)在线性链表中寻找包含元素x的前一个结点q。 第2章 基本数据结构及其运算 * (3)将结点p插入到结点q之后: ①使结点p指向包含元素x的结点,即 NEXT(p)=NEXT(q) ②使结点q的指针域内容改为指向结点p,即 NEXT(q)=p 第2章 基本数据结构及其运算 * 线性链表的插入算法: 输入:线性链表的头指针HEAD;插入位置处的前一个结点值x;插入的新元素b。 输出:插入后的线性链表。 PROCEDURE Inslst(HEAD,x,b) New(p) V(p)=b IF (HEAD=0) THEN { Head=p; Next(p)=0; RETURN } IF (V(head)=x) THEN { Next(p)=head; Head=p; RETURN } Lookst(head,x,q) Next(p)=next(q); Next(q)=p Return 第2章 基本数据结构及其运算 * 算法转换成C语言描述如下: #include stdlib.h struct node /*定义结点类型*/ { ET d; struct node *next; }; inslst(head,x,b) ET x,b; struct node **head; { struct node *p, *q; p=(struct node *)malloc(sizeof(struct node)); p-d=b; /*置结点的数据域*/ if (*head==NULL) /*链表为空*/ { *head=p;p-next=NULL;return;} if ((*head-d)==x) /*在第一个结点前插入*/ { p-next=*head;*head=p;return;} q=lookst(*head,x); /*寻找包含元素x的前一个结点q*/ p-next=q-next;q-next=p; /*结点p插到结点q之后*/ return;} 第2章 基本数据结构及其运算 * (3) 线性链表的删除 在链式存储结构下的线性表中 删除包含指定元素的结点。 第2章 基本数据结构及其运算 * 可利用栈与线性链表 第2章 基本数据结构及其运算 * (1)寻找包含元素x的前一个结点q。则包含元素x的结点序号 p=NEXT(q)。 (2)将结点q后的结点p删除,即 NEXT(q)=NEXT(p)。 第2章 基本数据结构及其运算 * (3)将包含元素x的结点p送回可利用栈。 第2章 基本数据结构及其运算 * 线性链表的删除算法: 输入:线性链表的头指针HEAD;需删除的元素x。 输出:删除后的线性链表。 PROCEDURE DELST(HEAD,x) IF (HEAD=0) THEN { “This is a empty list!”; RETURN } IF (V(HEAD)=x) THEN { p=NEXT (HEAD);DISPOSE(HEAD);HEAD=p; RETURN } LOOKST(HEAD,x,q) IF (NEXT(q)=0) THEN {“No this node in the list!” ;RETURN} p=NEXT(q); NEXT(q)=NEXT(p) DISPOSE(p) RETURN 第2章 基本数据结构及其运算 * 算法转换成C语言描述如下: #include stdlib.h struct node /*定义结点类型*/ { ET d; struct node *next; }; delst(head,x) ET x; struct node **head; { struct node *p, *q; if (*head==NULL) /*链表为空*/ { printf(This is a empty list!\n);return;} if ((*head-d)==x) /*删除第一个结点*/ { p=*hea
文档评论(0)