qq_52797084 2022-09-27 18:06 采纳率: 33.3%
浏览 28
已结题

删除单链表中的元素为什么用递归方法会出现负值,应该怎么解决?

void deleteX(Link p,int delnum)
{
//采取递归方法
struct Link
q;
if (p == NUL

```c++

```L)
{
return;
}
if (p->data== delnum)
{
q=p;
p = p->next;
free(q);
deleteX(p, delnum);
}
else
{
deleteX(p->next, delnum);
}
得到结果:

img

为什么采用递归的方法删除元素得到的结果会是-572662307,应该怎么解决?

  • 写回答

1条回答 默认 最新

  • qzjhjxj 2022-09-27 20:13
    关注

    修改如下,供参考:

    //采取递归方法  删除单链表中的元素
    void deleteX(struct Link* p,int delnum)
    {
    
        struct Link* q = NULL;
        if (p->next == NULL)
            return;
        if (p->next->data == delnum){
            q = p->next;
            p->next = q->next;
            free(q);
            deleteX(p, delnum);
        }
        else{
            deleteX(p->next, delnum);
        }
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 10月7日
  • 已采纳回答 9月29日
  • 创建了问题 9月27日

悬赏问题

  • ¥15 基于卷积神经网络的声纹识别
  • ¥15 Python中的request,如何使用ssr节点,通过代理requests网页。本人在泰国,需要用大陆ip才能玩网页游戏,合法合规。
  • ¥100 为什么这个恒流源电路不能恒流?
  • ¥15 有偿求跨组件数据流路径图
  • ¥15 写一个方法checkPerson,入参实体类Person,出参布尔值
  • ¥15 我想咨询一下路面纹理三维点云数据处理的一些问题,上传的坐标文件里是怎么对无序点进行编号的,以及xy坐标在处理的时候是进行整体模型分片处理的吗
  • ¥15 CSAPPattacklab
  • ¥15 一直显示正在等待HID—ISP
  • ¥15 Python turtle 画图
  • ¥15 stm32开发clion时遇到的编译问题