河北村村长 2015-05-21 05:14 采纳率: 0%
浏览 2284

单链表中查找结点p并删除结点p

pointer *p,*q=NULL;
p=find(head,i+1);
cout<data< q->next=p;
q->next=p->next;
delete p;
}
网上的实现方法都是删除p的后继结点,我想直接删除p,按照我的想法上述语句应该是正确的,但是执行时候在q->next=p出显示又断点,怎么破 大神救我

  • 写回答

7条回答 默认 最新

  • 存钱买冰棍 2015-05-21 10:13
    关注

    你应该从头结点开始遍历
    比如说头结点为 L;
    假设你要删的结点为p
    设置一个 q=L;
    m=q->next;
    while(m->next!=null)
    {
    if(m==p)
    {
    q->next=m-next;
    }
    else
    {
    m=m->next;
    q=q->next;
    }
    }

    评论

报告相同问题?

悬赏问题

  • ¥15 matlab实现基于主成分变换的图像融合。
  • ¥15 对于相关问题的求解与代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 信号傅里叶变换在matlab上遇到的小问题请求帮助
  • ¥15 保护模式-系统加载-段寄存器
  • ¥15 电脑桌面设定一个区域禁止鼠标操作
  • ¥15 求NPF226060磁芯的详细资料
  • ¥15 使用R语言marginaleffects包进行边际效应图绘制
  • ¥20 usb设备兼容性问题
  • ¥15 错误(10048): “调用exui内部功能”库命令的参数“参数4”不能接受空数据。怎么解决啊