题目描述:
假设有一个没有头指针的单链表。一个指针指向此单链表中间的一个节点(非第一个节点, 也非最后一个节点)。
请将该节点从单链表中删除。
分析与解答:
若要删除该节点,正常情况下,应该要知道该节点的前面节点的指针,
但是由于单链表中没有头结点,所以无法追溯到该节点前面的那个节点,
设该节点为B,下一个节点为C。那么,首先将B节点的内容替换为C节点的内容,
然后,将C节点删除,这样就达到了我们的目的。
代码如下:
pcur->next = pnext->next;
pcur->data = pnext->date;
delete pnext;
扩展题:
将一个单链表,在只遍历一遍的情况下,将单链表中的元素顺序反转过来。
void reverseList(node* head)
{
node *p=head,*previous=NULL,*next=NULL;
while(p->next!=NULL)
{
next=p->next;//保存下一个
p->next=previous;//p下一个为他前面的
previous=p;
p=next;
}
p->next=previous;
while(p!=NULL)
{
printf("%d ", p->date);
p=p->next;
}
printf("\n");
}