Yinsel
2021-10-01 22:57
采纳率: 66.7%
浏览 25

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 无用
    打赏 举报
查看更多回答(1条)

相关推荐 更多相似问题