C语言创建单链表的问题!! 求高手帮看看是什么问题。。

#include<stdio.h>#include<stdlib.h>typedefstructNode{intdate;structNode*next;}LNode,*... #include<stdio.h>
#include <stdlib.h>
typedef struct Node
{
int date;
struct Node *next;
}LNode,*LinkList;
int main()
{
void creatList(int ,LinkList);
void Visit(LinkList);
int length;
printf("input the length of List:\n");
scanf("%d",&length);
LinkList L;
creatList(length,L);
Visit(L);
free(L);
return 0;
}
void creatList(int Length,LinkList L)
{
L=(LinkList)malloc(sizeof(LNode));
int i;
LinkList Body;
for(i=0;i<Length;i++)
{
Body=(LinkList)malloc(sizeof(LNode));
if(i==0)
{
L->next=Body;
Body=Body->next;
}
else if(i==Length-1)
{
scanf("%d",&(Body->date));
Body->next=NULL;
break;
}
else
{
scanf("%d",&(Body->date));
Body=Body->next;
}
}
}
void Visit(LinkList L)
{
LinkList p;
p=(LinkList)malloc(sizeof(LNode));
L->next=p;
while(p->next!=NULL)
{
printf("%d",p->date);
p=p->next;
}
free(p);
}
展开
 我来答
xuhongming251
2011-06-11 · TA获得超过174个赞
知道小有建树答主
回答量:221
采纳率:0%
帮助的人:154万
展开全部
#include<stdio.h>
#include <stdlib.h>

typedef struct Node
{
int date;
struct Node *next;
}LNode,*LinkList;

void creatList(int ,LinkList);
void Visit(LinkList);

int main()
{
int length;
printf("input the length of List:\n");
scanf("%d",&length);
LinkList L;//L应该在这里应该指向一个新的申请空间,不能在调用函数里申请。否则调用完毕就释放了
L=(LinkList)malloc(sizeof(LNode));//
L->next = NULL;//
creatList(length,L);
Visit(L);
free(L);
return 0;
}
void creatList(int Length,LinkList L)
{
//L=(LinkList)malloc(sizeof(LNode));
//L->next = NULL;//
int i;
LinkList Body;
LinkList p = L;//
for(i=0;i<Length;i++)
{
Body=(LinkList)malloc(sizeof(LNode));
scanf("%d",&(Body->date));
Body->next = NULL;
p->next = Body;
p = Body;//或者p = p->next;
/*if(i==0)
{
L->next=Body;
Body=Body->next;//Body->next是一个随机值,这样赋值没有任何意义
}
else if(i==Length-1)
{
scanf("%d",&(Body->date));
Body->next=NULL;
break;
}
else
{
scanf("%d",&(Body->date));
Body=Body->next;
}*/
}
}
void Visit(LinkList L)
{
LinkList p;
//p=(LinkList)malloc(sizeof(LNode));//不必再申请空间了,只要一个指针就够了
//L->next=p;
p = L->next;
while(p != NULL)
{
printf("%d",p->date);
p=p->next;
}
printf("\n");
//free(p);
}
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式