C语言/结构体题目

本文介绍了一个使用C语言实现的学生信息管理系统,通过结构体存储每位学生的学号、姓名及各科成绩,并利用冒泡排序算法按平均分对学生进行排序,最终输出平均分排名倒数第二的学生信息。

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

编写C语言代码,实现以下功能:

有N名学生,每个人的信息包括学号、姓名和语文、数学、英语、平均分等内容(用结构体表示 ),输出平均分排名倒数第2的学生信息。

 思路:先定义一个结构体student,内包括各个信息

因为是多个学生,定义一个student数组

定义数组时使用动态内存分布,实现让用户自己输入学生的数量

自定义一个input函数实现对每个数组内容的赋值(注意要用指针,要理解结构体数组传值得格式)

最后用冒泡算法排序数组位置,方便找到平均分倒数第二的学生

#include <stdio.h>
#include<stdlib.h>
struct  student
{
	int num;
	char name[10];
	int chinese;
	int math;
	int english;
	int average;               //注意结构体的定义不能用式子(int average=(a+c+v)\3)错误

};

void input(student*p) {

	scanf_s("%d", &p->num);
	//gets_s(p->name);                      //c语言下不知道为什么无法用结构体变量gets()输入
	scanf("%s",&p->name);
	scanf_s("%d%d%d", &p->chinese, &p->math,&p->english);      //p->chinese 相当于 p.Chinese(前面加&效果一样,但是注意->前面是地址类型,.前面是变量容器类型)
	p->average = (p->chinese + p->math + p->english) / 3;     
}

int main()
{
	int n,i,j,temp;
	student *p;
	printf("输入学生人数N\n");
	scanf_s("%d", &n);
	p = (student*)malloc(sizeof(int)*n);     //动态内存分配,申请一个动态数组

	printf("请输入学生的学号,姓名,语文,数学,英语成绩\n");

	for (i = 0; i< n; i++) {
		input(&p[i]);                       //把数组的每一位放入input函数,而不是放入整个数组
		printf("==============\n");
	}

	temp=p[i].average;	                      //冒泡算法,方便找到倒数第二位
	for(j=0;j<n-1;j++)
		for (i = 0; i< n-1-j; i++){
			if(p[i].average>p[i+1].average){
				temp=p[i+1].average;
				p[i+1].average=p[i].average;
				p[i].average=temp;

			}
		}
		
		printf("\n");
		printf("倒数第二位学生的信息\n");
		printf("学号为%d,姓名为%s\n",p[1].num, p[1].name);
		printf("语文成绩:%d,数学:%d,英语成绩:%d,平均成绩为%d\n",p[1].chinese, p[1].math, p[1].english,p[1].average);


		return 0;
}

需要注意:

1注意理解结构体变量,在数组,指针,自定义函数,动态内存分配中的运用方式

2注意结构体的定义不能用式子 例如(int average=(a+c+v)\3)错误

3p->chinese 相当于 p.Chinese(前面加&效果一样,但是注意->前面是地址类型,.前面是变量容器类型)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值