中数据逆序输出_C语言 | 建立链表,输出各结点中的数据

本文介绍了如何使用C语言创建一个包含3个学生数据的链表,并详细解释了链表结构,头指针的作用以及如何逆序输出链表节点中的数据。
摘要由CSDN通过智能技术生成

8e5253ca253efa8e6851ea6138fb1250.png

例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.1fn",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
请按任意键继续. . .
C语言 | 简单链表​mp.weixin.qq.com
ee20caa1038b335d35634106d19cfd60.png
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值