p->next=p;和p=p->next;有什么区别?

问题描述:

p->next=p;和p=p->next;有什么区别?

p->next=p表示节点p的下一个节点还是p,如果链表只有p节点,那么这样就变成了一个循环链表
p=p->next表示修改指针p的位置,把p指向原来的下一个节点你的意思是p->next=p是修改结点位置,而p=p->next是修改指针位置?不是,假如链表为p1-p2-p3-.......p1->next=p1,那么链表就断了,p2,p3会找不到了,链表变成了p1--||-----| 也就是它自己指向自己了p1->next=p1,那么链表就断了,p2,p3会找不到了 这个不是通过将指向p1的指针转到指向p2,使得p1消失?怎么会p2,p3找不到呢这里有一个连如下:......->[0000]->[1111]->[2222]->[3333]->........ | p 开始时p指向节点[0000],那么p->next指向的是节点[1111]如果执行语句p->next=p,实际上就是修改了指针p->next的位置,p没有变,链表变成了:......->[0000]->||_____| p这个样了,其它节点还在,但是不能遍历它们了,因为p->next 还是它自己本身,所以其它节点就找不到了如果执行p=p->next,这样是修改了p位置,链表变成如下:......->[0000]->[1111]->[2222]->[3333]->........ | p昨晚办公室关没了,没来得及看哈 嗯嗯,终于理解了,不过我怎么觉得那p->next=p;没什么用了。。。那就要看特定情况下了,例如创建一个没有头结点的循环链表时,开始第一个节点就要这样了,如果不是第一个节点那就有 p->next=head; head表示第一个节点,p为最后一个节点