在例9.9和例9.10的基础上,写一个函数del,用来删除动态链表中指定的结点。
例题9.9:
#include<stdio.h>
#include<stdlib.h>
#define LEN sizeof(struct Student)
struct Student
{long num;
float score;
struct Student * next;
};
int n; //n为全局变量,本文件模块中各函数均可使用它
struct Student*creat(void) //定义函数。此函数返回一个指向链表头的指针
{struct Student * head;
struct Student*p1,*p2;
n=0;
p1=p2=(struct Student*)malloc(LEN); //开辟一个新单元
scanf("%ld,%f",&p1->num,&p1->score); //输入第1个学生的学号和成绩
head=NULL;
while(p1->num!=0)
{n=n+1;
if(n==1)head=p1;
else p2->next=p1;
p2=p1;
p1=(struct Student*)malloc(LEN); //开辟动态存储区,把起始地址赋给pl
scanf("%ld,%f",&p1->num,&p1->score); //输入其他学生的学号和成绩
p2->next=NULL;
return(head);
}
//写一个main函数,调用这个creat函数
int main()
{struct Student*pt; //函数返回链表第一个结点的地址
pt=creat();
printf("\nnum:%ld\nscore:%5.1f\n",pt->num,pt->score); //输出第1个结点的成员值
return 0;
}