ch11_14.c
来自「C语言程序设计上机指导与练习 冶金工业出版社 刘怀亮」· C语言 代码 · 共 30 行
C
30 行
/*CH11_14*/
/*写一个函数,删除链表中的指定结点。删除一个结点有两种情况*/
TYPE * delete(TYPE * head,int num)
{
TYPE *pf,*pb;
if(head==NULL) /*如为空表, 输出提示信息*/
{
printf("\nempty list!\n");
goto end;}
pb=head;
while (pb->num!=num && pb->next!=NULL)
/*当不是要删除的结点,而且也不是最后一个结点时,继续循环*/
{
pf=pb;pb=pb->next; /*pf指向当前结点,pb指向下一结点*/
}
if(pb->num==num)
{
if(pb==head) head=pb->next;
/*如找到被删结点,且为第一结点,则使head指向第二个结点,*/
/*否则使pf所指结点的指针指向下一结点*/
else pf->next=pb->next;
free(pb);
printf("The node is deleted\n");
}
else
printf("The node not been foud!\n");
end:
return head;
}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?