Yinsel 2021-10-01 22:57 采纳率: 66.7%
浏览 30
已结题

C语言数据结构链表的创建,运行后为什么在36行报错:Segmentation fault

```c

#include<stdio.h>
#include<malloc.h>
#define OK 1
#define ERROR 0
typedef int ElemType,Status;
typedef struct LNode
{
ElemType data;
struct LNode *next;
}LNode,*LinkList;
LinkList L;
LNode *p;
Status InitList(LinkList L);
void CreatList_H(LinkList L,int n);
int main()
{
CreatList_H(L,6);
return 0;
}

Status InitList(LinkList L)
{
L=(LinkList)malloc(sizeof(int));
L->next=NULL;
return OK;
}

void CreatList_H(LinkList L,int n)
{
InitList(L); //初始化链表30行
for(int i=0;i<n;++i)
{
p=(LNode *)malloc(sizeof(int));
scanf("%d",&p->data);
p->next=NULL;
L->next=p; //报错处36行
}
}

```查阅相关资料可知原因是使用指针时未初始化指针,可在30行已经调用InitList(L)初始化,问题出在哪呢,望各位帮我寻找一下问题,谢谢

  • 写回答

2条回答 默认 最新

  • CSDN专家-link 2021-10-02 05:45
    关注

    初始化函数参数改为LinkList*
    或者改为LinkList Initlist(LinkList L);函数闪最后return L;调用的时候改成L=Initlist(L);

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

报告相同问题?

问题事件

  • 系统已结题 10月10日
  • 已采纳回答 10月2日
  • 创建了问题 10月1日