C语言问题,求详解~~~~

假定已建立一下链表结构,且指针p和q已指向如图所示的结点:
则以下选项中
可将q所指结点从链表中删除并释放该结点的语句组是
A)(*p).next=(*q).next; free(p);    B)p=q->next; free(q);
C)p=q; free(q);            D)p->next=q->next; free(q);

删除q节点,
首先要把q的next的值赋给p的next域,即p->next=q->next
否则整个链表就断开了。
然后释放q.
所以选D
---------------------------------------
B、p=q->next是把指针p移动到q 的下一位,不能删除q,free(q)没用的。
A、p,q本就是指针加*取其内容再.next不知其意。
温馨提示:内容为网友见解,仅供参考
第1个回答  2012-09-16
先把q下一个元素连接到上一个:p=q->next
然后再释放q:free(q)
答案是B追问

D为什么不对?

本回答被网友采纳
第2个回答  2012-09-16
答案是A,
(*p).next=(*q).next; //将p的next指向c,(*q).next就是c
相似回答