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 乌班图ip地址配置及远程SSH
  • ¥15 怎么让点阵屏显示静态爱心,用keiluVision5写出让点阵屏显示静态爱心的代码,越快越好
  • ¥15 PSPICE制作一个加法器
  • ¥15 javaweb项目无法正常跳转
  • ¥15 VMBox虚拟机无法访问
  • ¥15 skd显示找不到头文件
  • ¥15 机器视觉中图片中长度与真实长度的关系
  • ¥15 fastreport table 怎么只让每页的最下面和最顶部有横线
  • ¥15 java 的protected权限 ,问题在注释里
  • ¥15 这个是哪里有问题啊?