//编写程序建立动态链表,实现3名学生数据的单向动态链表,并将链表中各结点的数据依次输出
#include<stdio.h>
#include<stdlib.h>
#define LEN sizeof(struct student)
struct student{
int num; //学号
char name[10]; //名字
double score; //成绩
struct student *next;
};
int main()
{
system("color 07");
struct student *head;
struct student *p1,*p2;
head=NULL;
p1=p2=(struct student*)malloc(LEN);
int n=0;
printf("Please enter the number,the name and the score of three students:\n");
scanf("%d %s %lf",&(*p1).num,&(*p1).name,&(*p1).score);
while((*p1).score!=0 && n<3){
n+=1;
if(n==0){
head=p1;
}else{
(*p2).next=p1;
}
p2=p1;
p1=(struct student*)malloc(LEN);
if(n<3){
scanf("%d %s %lf",&(*p1).num,&(*p1).name,&(*p1).score);
}
}
p2=NULL;
printf("Their information is:\n");
struct student *p;
p=head;
int x;
for(x=0;x<=n;x++){
printf("number:%d name:%s score:%lf\n",(*p).num,(*p).name,(*p).score);
p=(*p).next;
}
return 0;
}
为什么在第41行 head 的地址会变为了0 ,不应该是指向第一个结点吗?