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日
手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部