关于这个程序在释放temp时怎么不会把一部分链表给删了

不用先另term->next=NULL,吗... 不用先另term->next=NULL,吗 展开
 我来答
风若远去何人留
2017-03-05 · 知道合伙人互联网行家
风若远去何人留
知道合伙人互联网行家
采纳数:20412 获赞数:450134
专业C/C++软件开发

向TA提问 私信TA
展开全部
这个代码分为三部分
如果temp也即是head 本身就是NULL 说明是空链表 不做处理 直接返回
如果第一个节点就是data节点 那么做head=head->next 这样就做到了head后移 free temp的时候 不会影响head, 返回的head只是少了一个数据
如果data在中间 那么prev是data的上一个节点
先做prev->next = temp->next 就等于把data所在节点的下一个节点 连到了data上一个节点上

也就是 原本是P->data->N这样的连接 改成了 P->N 也就是删除了data所在的节点

所以 这个函数只删除最多一个节点 而不会删除一部分链表。
追问
可是此时temp中还连着他的下一个结点。prev也连着他的下一个结点。就是temp和prev都连着同一个
追答
只是值而已,不会影响链表。释放的只是节点内存,不会影响next
来自:求助得到的回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式