新手提问,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个回答

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

head是空指针,没有分配内存,当然报错啦

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
立即提问
相关内容推荐