Fly.c 2022-03-06 07:14 采纳率: 75%
浏览 21
已结题

c语言动态内存分配问题,Linux平台问题

Linux平台,好像动态内存分配的函数不好使了,无法给链表头节点初始化

img

typedef struct LinkList
{
  char data;
  struct LinkList* next;
}Node,*LinkList;
//初始化单链表,创建一个头指针与一个头结点
Status InitList(LinkList l)
{
  l =(Node*)calloc(1,sizeof(Node));//头结点
  l->next = NULL;//初始化头结点
  l->data = 0;
  return OK;
}
Elemtype InsertList(LinkList l,Elemtype e,int i)//在第i个元素之前插入
{
   if(i<0 || i>Length(l)+1)
       return 0;
    Node* new =(Node*)malloc(sizeof(Node));//新节点
   while(--i)
     l = l->next;
   new->data = e;//节点值
   new->next = l->next;
   l->next = new;
   l->data++;
   return e;
}

Status Create_tail(LinkList l,Elemtype* e,int i)
{
  if(!Empty(l))
      return ERROR;
  int j = 0;
  while(i - j)
  {
    InsertList(l,*(e+j),l->data+1);
    ++j;
  }
  return OK;
}

int main()
{
    int i = 0;
    Elemtype a[10],e;
  LinkList h;
  InitList(h);
  scanf("%s",a);
  Create_tail(h,a,strlen(a));
  DispList(h);
  printf("%d\n",Length(h));
  if(Empty(h))
      printf("此链表为空\n");
  else
      printf("此链表不为空\n");
  GetElem(h,3,&e);
  printf("%c\n",e);
  LocateElem(h,'V');
  InsertList(h,'D',7);
  DispList(h);
  DeleList(h,&e,1);
  DispList(h);
  DestoryList(h);
  return 0;
}

  • 写回答

1条回答 默认 最新

  • 真相重于对错 2022-03-06 09:02
    关注

    参数用二级指针

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 3月14日
  • 已采纳回答 3月6日
  • 创建了问题 3月6日

悬赏问题

  • ¥15 乌班图ip地址配置及远程SSH
  • ¥15 怎么让点阵屏显示静态爱心,用keiluVision5写出让点阵屏显示静态爱心的代码,越快越好
  • ¥15 PSPICE制作一个加法器
  • ¥15 javaweb项目无法正常跳转
  • ¥15 VMBox虚拟机无法访问
  • ¥15 skd显示找不到头文件
  • ¥15 机器视觉中图片中长度与真实长度的关系
  • ¥15 fastreport table 怎么只让每页的最下面和最顶部有横线
  • ¥15 R语言卸载之后无法重装,显示电脑存在下载某些较大二进制文件行为,怎么办
  • ¥15 java 的protected权限 ,问题在注释里