请问各位高手,c语言中怎么建立一个带有头节点的链表

 我来答
sfg13141314
推荐于2017-11-25
知道答主
回答量:36
采纳率:0%
帮助的人:17.9万
展开全部
head=(node*)malloc(sizeof(node));/ /创建头结点
head->next=NULL;
while(n--)
{
printf("\n请输入单链表第%d个结点的值:",i++);
scanf("%d",&a);
p=(node*)malloc(sizeof(node));
p->info=a;
p->next=head->next;
head->next=p;
}
追问
能不能详细一点呢
追答
#include "stdio.h"
typedef int datatype;
typedef struct link_node
{
datatype info;
struct link_node *next;
}node;
main()
{
int i=1,n,a;
node *head,*p,*q;
printf("\n本程序建立带头结点的单链表:\n");
printf("请输入你所需要建立带头结点的单链表的结点数:");
scanf("%d",&a);
head=(node*)malloc(sizeof(node));
head->next=NULL;
while(a)
{
printf("\n请输入单链表第%d个结点的值:",i++);
scanf("%d",&n);
if(n==0)
break;
p=(node*)malloc(sizeof(node));
p->info=n;

p->next=head->next;
head->next=p;

a--;
}
if(!head->next) printf("\n单链表是空的!\n");
else
{
printf("\n单链表各个结点的值分别为:\n");
q=head->next;
while(q)
{

printf("%5d",q->info);/*输出非空表中第一个结点的值*/
q=q->next;/*p指向第一个结点的下一个结点*/
}
}
printf("\n");

}
十月雪1992
2012-04-20
知道答主
回答量:24
采纳率:0%
帮助的人:8.2万
展开全部
结点的数据域置空,next指向开始结点
追问
哪个节点置为空啊
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式