C语言 | 建立链表,输出各结点中的数据
【摘要】 例42:C语言实现一个简单链表,它由3个学生数据的结点组成,要求输出各结点中的数据。解题思路:读者在学习这道例题的时候,应该首先分析三个问题。各个结点是怎么样构成链表的?没有头指针head行不行?p起什么作用,没有它行不行?源代码演示:#include<stdio.h>//头文件
struct student //定义学生结构体
{
int num; //学号
f...
例42:C语言实现一个简单链表,它由3个学生数据的结点组成,要求输出各结点中的数据。
解题思路:读者在学习这道例题的时候,应该首先分析三个问题。
- 各个结点是怎么样构成链表的?
- 没有头指针head行不行?
- p起什么作用,没有它行不行?
源代码演示:
#include<stdio.h>//头文件
struct student //定义学生结构体
{
int num; //学号
float score;//成绩
struct student *next;
};
int main()//主函数
{
struct student a,b,c;//定义结构体变量
struct student *head,*point;//定义结构体指针变量
a.num=10101;//学号赋值
a.score=89.5;//成绩赋值
b.num=10103;//学号赋值
b.score=90.0;//成绩赋值
c.num=10107;//学号赋值
c.score=85.0;//成绩赋值
head=&a;//将第1个结点的起始地址赋给头指针head
a.next=&b;//将第2个结点的起始地址赋给第1个结点的next成员
b.next=&c;//将第3个结点的起始地址赋给第2个结点的next成员
c.next=NULL;//第3个结点的next成员赋给null
point=head;
do //do while循环
{ printf("%ld %5.1f\n",point->num,point->score);//输出结果
point=point->next;
}
while(point!=NULL);
return 0;//主函数返回值为0
}
编译运行结果如下:
10101 89.5
10103 90.0
10107 85.0
--------------------------------
Process exited after 0.04469 seconds with return value 0
请按任意键继续. . .
文章来源: zhuanlan.zhihu.com,作者:,版权归原作者所有,如需转载,请联系作者。
原文链接:zhuanlan.zhihu.com/p/338876107
【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
评论(0)