Yinsel 2021-10-02 12:13 采纳率: 66.7%
浏览 39
已结题

C语言链表问题:为什么free(p)后二次用malloc分配内存会导致不能正确打印链表?


#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,**LinkListP;
LinkList L;
LNode *p;
Status InitList(LinkListP L);
Status CreatList_H(LinkListP L,int n);
int main()
{
    int n;
    scanf("%d",&n);
    CreatList_H(&L,n);
    p=(LNode *)malloc(sizeof(LNode));                          //free(p)后二次动态分配内存
    p=L->next;
    for(int i=0;i<n;i++)
    {
        printf("%d\n",p->data);
        p=p->next;
    }
    return 0;
}

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

Status CreatList_H(LinkListP L,int n)
{
    InitList(L);
    for(int i=0;i<n;i++)
    {
        p=(LNode *)malloc(sizeof(LNode));
        scanf("%d",&(p->data));
        p->next=(*L)->next;
        (*L)->next=p;
    }
    free(p);p=NULL;                         //删除此行链表正确打印
    return OK;
}

本人C关于内存方面的知识掌握得不是很牢固,望各位能指出的我的问题,谢谢!

  • 写回答

2条回答 默认 最新

  • qzjhjxj 2021-10-02 13:08
    关注

    第48行,free(p),是把刚生成的链表的最后一个结点释放了,链表断了尾巴?
    第21行,这句多余,p 是指针,在这里让它指向链表的头结点就可以了,不需要申请一个空间。

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

报告相同问题?

问题事件

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

悬赏问题

  • ¥15 对于知识的学以致用的解释
  • ¥50 三种调度算法报错 有实例
  • ¥15 关于#python#的问题,请各位专家解答!
  • ¥200 询问:python实现大地主题正反算的程序设计,有偿
  • ¥15 smptlib使用465端口发送邮件失败
  • ¥200 总是报错,能帮助用python实现程序实现高斯正反算吗?有偿
  • ¥15 对于squad数据集的基于bert模型的微调
  • ¥15 为什么我运行这个网络会出现以下报错?CRNN神经网络
  • ¥20 steam下载游戏占用内存
  • ¥15 CST保存项目时失败