|
|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
struct student *del( struct student *head, int num)
{
struct student *p1, *p2;
if( NULL == head ) // 如果头结点指向NULL,这是一个空链表。纯属忽悠T_T
{
printf("\nThis list is null!\n");
goto END;
}
p1 = head;
while( p1->num != num && p1->next != NULL) //这一行代码的目的是什么求详细
{
p2 = p1; //这一行代码的目的是什么求详细
p1 = p1->next; //这一行代码的目的是什么求详细
}
if( num == p1->num )
{
if( p1 == head ) // 当将要删除的结点位于头结点的时候
{
head = p1->next;
}
else // 一般情况
{
p2->next = p1->next;
}
printf("\nDelete No: %d succeed!\n", num);
n = n-1; // n是作为一个全局变量,用来记录链表的数据数。
}
else
{
printf("%d not been found!\n", num);
}
|
|