怎样创建一个线性链表(C语言)?

 我来答
浦竹青柏己
2020-01-15 · TA获得超过3.7万个赞
知道大有可为答主
回答量:1.3万
采纳率:33%
帮助的人:909万
展开全部
可以用头插法或尾插法
(下面用尾插法)
思想为:让你输入一串字符串,
为每个字符创建一个节点,添加到链表的后面.直到输入的字符为@为止.
#include
<stdio.h>
#include
<malloc.h>
typedef
char
datatype;
typedef
struct
node
{
datatype
data;
struct
node
*next;
}linklist;
linklist
*p,*q,*head;
main()
{
char
c;
head
=
(linklist
*)malloc(sizeof(linklist));
head->next
=
NULL;
p
=
head;
c
=
getchar();
while(c
!=
'@')
{
q
=
(linklist
*)malloc(sizeof(linklist));
q->data
=
c;
q->next
=
NULL;
p->next
=
q;
p
=
p->next;
c
=
getchar();
}
}
可以在
main()
最后加上
for(p=head->next;
p!=NULL;
p=p->next)
{
printf("%5c",
p->data);
}
来测试结果,本人已经TC
2.0下面测试通过.
撒合英兰昭
2020-01-09 · TA获得超过3.8万个赞
知道大有可为答主
回答量:1.4万
采纳率:34%
帮助的人:913万
展开全部
可以用头插法或尾插法
(下面用尾插法)
思想为:让你输入一串字符串,
为每个字符创建一个节点,添加到链表的后面.直到输入的字符为@为止.
#include
<stdio.h>
#include
<malloc.h>
typedef
char
datatype;
typedef
struct
node
{
datatype
data;
struct
node
*next;
}linklist;
linklist
*p,*q,*head;
main()
{
char
c;
head
=
(linklist
*)malloc(sizeof(linklist));
head->next
=
NULL;
p
=
head;
c
=
getchar();
while(c
!=
'@')
{
q
=
(linklist
*)malloc(sizeof(linklist));
q->data
=
c;
q->next
=
NULL;
p->next
=
q;
p
=
p->next;
c
=
getchar();
}
}
可以在
main()
最后加上
for(p=head->next;
p!=NULL;
p=p->next)
{
printf("%5c",
p->data);
}
来测试结果,本人已经TC
2.0下面测试通过.
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
夏侯孝佟雪
2020-03-24 · TA获得超过3.6万个赞
知道大有可为答主
回答量:1.3万
采纳率:35%
帮助的人:733万
展开全部
那么typedey
struct
node是什么意思呢
答:
是给结构“struct
node”起的名字“node”,以后就可以直接用“node”定义变量,就像用“int”……
还有struct
node
*next?
答:
是链表中指向节点的指针
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式