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日

悬赏问题

  • ¥50 永磁型步进电机PID算法
  • ¥15 sqlite 附加(attach database)加密数据库时,返回26是什么原因呢?
  • ¥88 找成都本地经验丰富懂小程序开发的技术大咖
  • ¥15 如何处理复杂数据表格的除法运算
  • ¥15 如何用stc8h1k08的片子做485数据透传的功能?(关键词-串口)
  • ¥15 有兄弟姐妹会用word插图功能制作类似citespace的图片吗?
  • ¥200 uniapp长期运行卡死问题解决
  • ¥15 latex怎么处理论文引理引用参考文献
  • ¥15 请教:如何用postman调用本地虚拟机区块链接上的合约?
  • ¥15 为什么使用javacv转封装rtsp为rtmp时出现如下问题:[h264 @ 000000004faf7500]no frame?