求教free(q);q=q->nextvoid delnodes(Linklist &L,ElemType min,Elemtype max){ LinkList *p=L,*q=p->next,*r;while(q!=null){if(q->data>=min&&q->datanext;p->next=q->next;free(q); q=r;}else{p=q;q=q->next;}}}为什么free(q),q已经被释放了,后面又能

来源:学生作业帮助网 编辑:作业帮 时间:2024/07/21 04:32:12
求教free(q);q=q->nextvoid delnodes(Linklist &L,ElemType min,Elemtype max){ LinkList *p=L,*q=p->next,*r;while(q!=null){if(q->data>=min&&q->datanext;p->next=q->next;free(q); q=r;}else{p=q;q=q->next;}}}为什么free(q),q已经被释放了,后面又能
xRrPro<Q1cIZa&@N)-TiP/#%~\ONX;krXw._:{u]Z8.9)CeDYe|<-)Od)_bizM"H"l&TKʥƩ!ԙg%k YN80S,e0(ә(ŢiiRdʌ>v;C* [qڦWԟ'wi,RspӒC:DKHxEbO7 !mhצkw4gS*++`9t`{Wˬ ˹GfկX ڃJ^4u?zsL>\ҸUC{cU&f9P + !N_΃;~};~oonfg0RJ.ٸ=/'t0l}xOz{ӺǦC8*

求教free(q);q=q->nextvoid delnodes(Linklist &L,ElemType min,Elemtype max){ LinkList *p=L,*q=p->next,*r;while(q!=null){if(q->data>=min&&q->datanext;p->next=q->next;free(q); q=r;}else{p=q;q=q->next;}}}为什么free(q),q已经被释放了,后面又能
求教free(q);q=q->next
void delnodes(Linklist &L,ElemType min,Elemtype max)
{
LinkList *p=L,*q=p->next,*r;
while(q!=null)
{
if(q->data>=min&&q->datanext;
p->next=q->next;
free(q);
q=r;
}else
{
p=q;q=q->next;
}
}
}
为什么free(q),q已经被释放了,后面又能把r赋给q呢?

求教free(q);q=q->nextvoid delnodes(Linklist &L,ElemType min,Elemtype max){ LinkList *p=L,*q=p->next,*r;while(q!=null){if(q->data>=min&&q->datanext;p->next=q->next;free(q); q=r;}else{p=q;q=q->next;}}}为什么free(q),q已经被释放了,后面又能
free释放的是q指针所指向的由malloc所分配的内存单元,q指针本身是不会释放的,所以之后可以将q指针重新指向新的内存地址,即指针r指向的位置;这里是因为外层有循环,所以需要将q指针移动到它的下一个元素,以便继续迭代执行.