数据结构实验之链表一:顺序建立链表
Time Limit: 1000ms Memory limit: 65536K 有疑问?点这里^_^
题目描述
输入N个整数,按照输入的顺序建立单链表存储,并遍历所建立的单链表,输出这些数据。
输入
第一行输入整数的个数N;
第二行依次输入每个整数。
第二行依次输入每个整数。
输出
输出这组整数。
示例输入
8 12 56 4 6 55 15 33 62
示例输出
12 56 4 6 55 15 33 62
提示
不得使用数组!
来源
示例程序
示例一:
#include<stdio.h>
#include<stdlib.h>
struct node
{
int data;
struct node *next;
};
int main()
{
struct node *head,*p,*tail;
int i,n;
scanf("%d",&n);
head=(struct node *)malloc(sizeof(struct node));
head->next=NULL;
tail=head;
for(i=0;i<n;i++)
{
p=(struct node *)malloc(sizeof(struct node));
scanf("%d",&p->data);
p->next=NULL;
tail->next=p;
tail=p;
};
p=head->next;
for(i=0;i<n-1;i++)
{
printf("%d ",p->data);
p=p->next;
}
printf("%d",p->data);
return 0;
}
可以将创建单链表的过程写成函数!
#include<stdio.h>
#include<stdlib.h>
struct node
{
int data;
struct node *next;
};
struct node *creat(int n)
{
struct node *head,*p,*tail;
int i;
head=(struct node *)malloc(sizeof(struct node));
head->next=NULL;
tail=head;
for(i=0;i<n;i++)
{
p=(struct node *)malloc(sizeof(struct node));
scanf("%d",&p->data);
p->next=NULL;
tail->next=p;
tail=p;
}
return head;
}
int main()
{
struct node *head,*p;
int n,i;
scanf("%d",&n);
head=creat(n);
p=head->next;
for(i=0;i<n-1;i++)
{
printf("%d ",p->data);
p=p->next;
}
printf("%d",p->data);
return 0;
}
本文介绍了一种通过输入整数序列来顺序建立单链表的方法,并提供了完整的C语言实现代码。该方法不使用数组,而是利用结构体节点来构建单链表,并能够遍历输出链表中的所有元素。
1241

被折叠的 条评论
为什么被折叠?



