关于链表的删除问题
从程序里截得一段struct student *del(struct student *head, int del_num)
{
struct student *p1,*p2;
if(head == NULL)
printf("\nlist null!!!\n"); /* 空表的情况 */
else
{
p1 = head;
while(del_num != p1->num && p1->next != NULL)
{
p2 = p1;
p1 = p1->next; /* p1后移1个结点 */
}
if(del_num == p1->num) /* 找到 */
{
if(p1 == head) /* 若p1指向的是首结点 */
head = p1->next; /* 把第二个结点的地址赋予head */
else
p2->next = p1->next; /*将下一结点地址富裕前一结点地址 */
}
else
printf("\n not found!!!\n");
}
return(head);
} 里面的while循环,问一下是怎么样查找到所要删除的序号的,总觉得}应该放在后面……