喀喀喀吃 2022-09-26 15:40 采纳率: 66.7%
浏览 48
已结题

单链表逆转,用三个指针实现,但是在链表为空时,显示段错误,为什么,该怎么改呢?

单链表逆转,用三个指针实现,但是在链表为空时,显示段错误,为什么,该怎么改呢?

struct ListNode *reverse( struct ListNode *head )
{
    struct ListNode *p ,*q, *h;
    h=head;
    q=p=head->next;
    h->next=NULL;
    if(head!=NULL)
    {
    while(p != NULL) {
        q=q->next;
        p->next = h;
        h=p;
        p = q;
    }
    return h;
    }
    else
        return head;
}
 

img

  • 写回答

3条回答 默认 最新

  • 私房菜 优质创作者: 移动开发技术领域 2022-09-26 16:04
    关注

    你的代码第 5 行,head 为NULL了,能那么引用?

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 10月3日
  • 已采纳回答 9月26日
  • 创建了问题 9月26日