7-1 学生信息输入输出 (10分)

本文介绍了一种使用单向链表实现学生信息输入输出的方法,通过尾插法组织学生信息,并按顺序输出。示例代码展示了如何在C语言中创建链表节点,插入学生数据,以及遍历链表进行输出。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

7-1 学生信息输入输出 (10分) PTA

输入若干个学生的信息(学号、姓名、成绩),当输入学号为0时结束,用单向链表组织这些学生信息后,再按顺序输出。

思路就是采用带头结点的尾插法,然后顺序顺换输出即可。

输入样例:

1 zhang 78
2 wang 80
3 li 75
4 zhao 85
0

输出样例:

1 zhang 78
2 wang 80
3 li 75
4 zhao 85
#include <stdio.h>
#include <stdlib.h>
struct ListNode{
    int data;
    char name[20];
    int score;
    struct ListNode *next;
};
int main(){//带头结点的尾插法。
	struct ListNode *head,*p,*tail;
	int x;
	head = (struct ListNode*)malloc(sizeof(struct ListNode));
	head->next = NULL;//千万记得给头结点初始化后继节点为NULL 
	tail = head;
	scanf("%d",&x);
	while(x != 0){
		p = (struct ListNode*)malloc(sizeof(struct ListNode));
		p->next = NULL; 
		p->data = x;
		scanf("%s%d",p->name,&p->score);
		tail->next = p;//给尾插啊!!!毕竟尾插法 
		tail = p;
		scanf("%d",&x);
	}
	tail->next = NULL;//注意结尾的后继节点为NULL
	 for(p = head->next; p != NULL; p = p->next){
	 	printf("%d %s %d\n",p->data,p->name,p->score);
	 }
	 return 0;
} 
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值