数据结构实验之链表一:顺序建立链表
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>
typedef struct node{// 创建链表
int data;
struct node *next;
}Node;
Node *creatList(int n){//顺序建立链表
int i;
Node *head,*p,*q;
head=(struct node *)malloc(sizeof(struct node)); //创建头结点
head->next=NULL;
q=head;
for(i=0;i<n;i++){
p=(struct node *)malloc(sizeof(struct node));
scanf("%d",&p->data);
p->next=NULL;
q->next=p;
q=p;
}
return (head);
}
void main()
{
int n,i;
struct node *head;
scanf("%d",&n);
head=creatList(n);
while(head->next!=NULL){ //遍历链表
if(head->next->next==NULL)
printf("%d\n",head->next->data);
else
printf("%d ",head->next->data);
head=head->next;
}
}