qq_39781557 2018-10-08 14:47 采纳率: 0%
浏览 548

新手提问,C语言链表的一个练习,这个程序为什么会卡住?

#include
#include

typedef struct _node{
int value;
struct _node *next;
}Node;

int main(int argc,char const *argv[])
{
Node *head=NULL;

int number;
do{
    scanf("%d",&number);
    if(number!=-1){
        Node *p=(Node*)malloc(sizeof(Node));
        p->value=number;
        p->next=head->next;
        head->next=p;
    }
}while(number!=-1);

for(Node *q=head->next;q;q=q->next){
    printf("%d",q->value);
}

for(Node *p=head;p;p=p->next){
    free(p);
}

return 0;

}

只能运行到第一次输入,卡在p->next=head->next;
图片说明

以及Program received signal SIGSEGV, Segmentation fault.

是因为head的next为NULL吗?

  • 写回答

2条回答 默认 最新

  • cold_windx 2018-10-09 00:59
    关注

    你head是NULL,你这个head指针指向的数据是不存在的,也就是head的next不存在

    评论

报告相同问题?