數據結構實驗之鏈表一:順序建立鏈表
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;
}