一个简单的学生管理系统(C语言)

本文介绍了一个使用C语言实现的学生信息管理系统,该系统能够手动输入学生数量,录入学生姓名、学号和分数,通过冒泡排序算法按分数升序排列并输出学生信息。系统采用结构体指针动态分配内存,实现了灵活的数据录入和排序功能。

功能:手动输入学生个数,然后录入各项数据后,排序后按分数由小到大输出数据。

#include <stdio.h>
#include <malloc.h>

struct Student
{
	char name[20];
	int num;
	float score;
};

int main(void)
{
	void input(struct Student *p, int n1);
	void sort(struct Student *s, int m);
	void output(struct Student *q, int n2);
	
	int len;
	struct Student *stu;                                                //定义结构体指针变量 
	stu = (struct Student *)malloc(len * sizeof(struct Student));       //动态构造一维数组 
	printf("请输入学生个数len = ");
	scanf("%d", &len);
	printf("请输入学生信息:\n\n");
	input(stu, len);
	sort(stu, len);
	printf("\n");
	output(stu, len);
	
	free(stu);                                                        //释放内存	 
	
	return 0;
}

void input(struct Student *p, int n1)            //数据录入
{
	int i;
	for (i = 0; i < n1; i++)
	{
		printf("请输入第%d个学生的信息\n", i+1);
		printf("请输入学生姓名:\n");
		printf("name = ");
		scanf("%s", p[i].name);                 //name 是数组名,本省就是首元素地址,不能再加& 
		
		printf("请输入学生学号:\n");
		printf("number = ");
		scanf("%d", &p[i].num);
		
		printf("请输入学生分数:\n");
		printf("score = ");
		scanf("%f", &p[i].score);
		printf("\n");
	}
}

void output(struct Student *q, int n2)         //数据输出 
{
	int i;
	for (i = 0; i < n2; i++)
	{
		printf("排序后第%d个学生的信息是:\n", i+1);
		printf("name = %s\n", q[i].name);
		printf("number = %d\n", q[i].num);
		printf("score = %.1f\n", q[i].score);
		printf("\n");
	}
}

void sort(struct Student *s, int m)           //冒泡排序,按学生成绩升序排序 
{
	int i, j;
	struct Student temp;
	for (i = 0; i < m-1; i++)
	{
		for(j = 0; j < m-1-i; j++)
		{
			if (s[j].score > s[j+1].score)   //注意:比较的是分数,但交换的是结构体变量 
			{
				temp = s[j];
				s[j] = s[j+1];
				s[j+1] = temp;
			}
		}
	}
}

运行结果
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值