问一个关于链表删除释放的问题

structNode*deleteNode(structNode*head){structNode*p1,*p2,*p3;p2=p1=head;while(p1!=NUL... struct Node* deleteNode(struct Node *head)
{
struct Node *p1,*p2,*p3;
p2=p1=head;
while(p1!=NULL)
{

if(p1->data%2!=0)
{
p2=p1;
p1=p1->next;
}
else
{
if(p1==head) head=p1->next;
else
{ p3=p2->next;
p2->next=p1->next;
p1=p1->next;
if(p3!=NULL)
{
delete(p3);
}
}
}

}
是偶数就把节点删除,但是释放删除节点的空间时程序会崩溃,哪里错了?比如输入 4 3 -1
展开
 我来答
高软件工程师
2014-05-03
知道答主
回答量:1
采纳率:0%
帮助的人:2.3万
展开全部
new/delete,malloc/free,不知道你在分配和释放内存的时候,这两对有没有匹配?
另外,当head->data是偶数时,你只是令head = p1->next,而p1还是指向原来那个
偶数的头结点,这将变成死循环。
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式