C语言实验-学生信息管理系统

news2024/11/20 15:24:02
  1. 按以下菜单界面编写学生信息管理系统;

1)录入学生信息首先输入学生人数,然后根据学生人数开辟动态数组;

2)学生信息包括学号、姓名、性别、三门课成绩、总分;其中学号、姓名、

性别、三门课成绩是需要从键盘录入的,而总分是由程序计算的,而不

是用户自己算了再输入。

3)显示结果(学生信息)要以列表的形式显示,注意美观性;

4)要有必要的容错措施,比如输入各科分数要在0-100之间,输入错误给

用户提示,让其重新输入;

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<iostream>
#include<Windows.h>
#include<assert.h>
using namespace std;

typedef struct student
{
	char ID[15];
	char name[15];
	char sex[5];
	int score[3];
	int totalscore;
}student;

typedef struct Data
{
	student* data;
	int size;
	int capacity;
}Data;

enum Option
{
	EXIT,//0
	ADD,
	PRINT,
	SEARCH_BY_ID,
	SEARCH_BY_NAME,
	SORT,
	FIND_BY_SCORE
};

void menu()
{
	cout << "\n*************************\n";
	cout << "1.录入学生信息\n";
	cout << "2.显示学生信息\n";
	cout << "3.按学号查找\n";
	cout << "4.按姓名查找\n";
	cout << "5.按总分递减排序\n";
	cout << "6.查找有2科目不及格的学生信息\n";
	cout << "0.退出\n";
	cout << "*************************\n";
	cout << "请输入功能号0-6:";

}


void Init(Data* pdata)
{
	assert(pdata);
	cout << "输入学生人数:" << endl;
	cin >> pdata->capacity;
	pdata->data = (student*)malloc(sizeof(student) * (pdata->capacity));
	pdata->size = 0;
	for (int i = 0; i < pdata->capacity; i++)
	{
		pdata->data[i].totalscore = 0;
	}

}
void fun1(Data*pdata)
{
	int flag = 0;
	if (pdata->size==pdata->capacity)
	{
		cout << "容量不够,无法输入" << endl;
		return;
	}
	
	cout << "输入学号:";
	scanf("%s",pdata->data[pdata->size].ID);
	cout << "输入姓名:";
	scanf("%s", pdata->data[pdata->size].name);
	cout << "输入性别:";
	scanf("%s", pdata->data[pdata->size].sex);
	
	do {
		cout << "输入三科成绩:";
		for (int i = 0; i < 3; i++)
		{
			scanf("%d", &pdata->data[pdata->size].score[i]);
			if (pdata->data[pdata->size].score[i] > 100 || pdata->data[pdata->size].score[i] < 0)
			{
				flag = 1;
			}//如果输入成绩不合法
			pdata->data[pdata->size].totalscore += pdata->data[pdata->size].score[i];
		}
		if (flag == 1)
		{
			cout << "成绩输入不合规,重新输入" << endl;
		}
	} while (flag != 0);
	cout << "信息输入成功" << endl;
	pdata->size++;
}
void fun2(Data* pdata)//打印信息
{
	assert(pdata);
	printf("%-10s%-10s%-5s%-12s%-5s\n", "学号", "姓名", "性别", "成绩", "总成绩");
	for (int i = 0; i < pdata->size; i++)
	{
		printf("%-10s%-10s%-5s%-4d%-4d%-4d%-5d\n",
			pdata->data[i].ID, 
			pdata->data[i].name, 
			pdata->data[i].sex, 
			pdata->data[i].score[0],
			pdata->data[i].score[1],
			pdata->data[i].score[2],
			pdata->data[i].totalscore);
	}
}
void fun3(Data*pdata)
{
	cout << "\n请输入要查找的学号:\n";
	char IDinput[15]="\0";
	cin >> IDinput;
	for (int i = 0; i < pdata->size; i++)
	{
		if (strcmp(pdata->data[i].ID, IDinput) == 0)
		{
			printf("%-10s%-10s%-5s%-12s%-5s\n", "学号", "姓名", "性别", "成绩", "总成绩");
			printf("%-10s%-10s%-5s%-4d%-4d%-4d%-5d\n",
				pdata->data[i].ID,
				pdata->data[i].name,
				pdata->data[i].sex,
				pdata->data[i].score[0],
				pdata->data[i].score[1],
				pdata->data[i].score[2],
				pdata->data[i].totalscore);
			break;
		}
	}
}
void fun4(Data*pdata)
{
	cout << "\n请输入要查找的姓名:\n";
	char nameinput[15] = "\0";
	cin >> nameinput;
	printf("%-10s%-10s%-5s%-12s%-5s\n", "学号", "姓名", "性别", "成绩", "总成绩");
	for (int i = 0; i < pdata->size; i++)
	{
		if (strcmp(pdata->data[i].name, nameinput) == 0)
		{
			printf("%-10s%-10s%-5s%-4d%-4d%-4d%-5d\n",
				pdata->data[i].ID,
				pdata->data[i].name,
				pdata->data[i].sex,
				pdata->data[i].score[0],
				pdata->data[i].score[1],
				pdata->data[i].score[2],
				pdata->data[i].totalscore);
		}
	}
}
int compare(const void* a, const void* b)
{
	return ((student*)b)->totalscore - ((student*)a)->totalscore;
}
void fun5(Data*pdata)//排序
{
	qsort(pdata->data, pdata->size, sizeof(student), compare);
	fun2(pdata);
}
void fun6(Data* pdata)
{
	for (int i = 0; i < pdata->size; i++)
	{
		int flag = 0;
		for (int j = 0; j < 3; j++)
		{
			if (pdata->data[i].score[j] < 60)
			{
				flag++;
			}
		}
		if (flag >= 2)
		{
			printf("%-10s%-10s%-5s%-4d%-4d%-4d%-5d\n",
				pdata->data[i].ID,
				pdata->data[i].name,
				pdata->data[i].sex,
				pdata->data[i].score[0],
				pdata->data[i].score[1],
				pdata->data[i].score[2],
				pdata->data[i].totalscore);
		}
	}
}

int main()
{
	int input = 0;

	Data data;

	Init(&data);
	do
	{
		menu();
		printf("请输入你的选择:>");
		scanf("%d", &input);
		system("cls");
		switch (input)
		{
		case ADD:
			fun1(&data);
			break;
		case PRINT:
			fun2(&data);
			break;
		case SEARCH_BY_ID:
			fun3(&data);
			break;
		case SEARCH_BY_NAME:
			fun4(&data);
			break;
		case SORT:
			fun5(&data);
			break;
		case FIND_BY_SCORE:
			fun6(&data);
			break;
		case EXIT:
			fun2(&data);
			printf("退出通讯录\n");
			break;
		default:
			printf("选择错误,重新选择\n");
			break;
		}
	} while (input);
	return 0;
}

测试用例可以自己简单测一测

取码点赞👍!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1641821.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

YOLO自研模块:多尺度轻量化卷积模块

目录 一、原理 二、代码 三、配置文件 一、原理 不同大小的卷积核,提取目标特征的特征尺度不同,所以通过使用不同大小卷积核的卷积来提取特征就可以保证获取到目标的多尺度特征。 借鉴YOLOv8中,将通道数进行划分的操作,在卷积的输入过程中为了减小参数量,将输入通道数…

截图时,VSCode屏幕泛白

问题如图所示&#xff1a; 放弃前摇&#xff0c;直接给出解决方案&#xff1a;换个主题即可。 实测&#xff0c;Light Modern 的色域正常&#xff0c;其他的没有经过测试。 出现这个问题的原因&#xff0c;大概率就是色彩空间不匹配。 HDR 内容是为了在支持 HDR 的显示设备上展…

H3C MSTP 实验

H3C MSTP 实验 实验拓扑 ​​ 实验需求 所有交换机上创建 Vlan10&#xff0c;Vlan20&#xff0c;Vlan30 和 Vlan40所有交换机之间的端口配置为 Trunk&#xff0c;并放行相关 VLAN按照图示分区域配置 MSTP&#xff0c;并配置主备根网桥 实验步骤 VLAN基础配置&#xff08;…

C++ 多态(二)

四、多态纯虚函数 纯虚函数是在C中用来定义抽象类的一种特殊函数。纯虚函数没有具体的实现&#xff0c;只有函数声明&#xff0c;它的作用是为派生类提供一个接口&#xff0c;让派生类必须实现这个函数。如果一个类中包含了纯虚函数&#xff0c;那么这个类就是抽象类&#xff…

史上最复杂的探测器嫦娥六号,如何采取人类首份月背样品? | 最新快讯

作者&#xff1a;LM-51D-YZ4D2&#xff0c;航天爱好者 今天&#xff0c;长征五号遥八火箭即将从海南文昌航天发射场点火起飞&#xff0c;把嫦娥六号探测器送入预定轨道。作为嫦娥五号的备份器&#xff0c;嫦娥六号继承了嫦娥五号的结构&#xff0c;又针对月球背面着陆进行了优化…

6.【Orangepi Zero2】localtime、asctime函数

【Orangepi Zero2】localtime、asctime函数 localtime、asctime localtime、asctime #include <time.h>struct tm *localtime(const time_t *timep); char *asctime(const struct tm *tm);localtime() 是 把从1970-1-1零点零分到当前时间系统所偏移的秒数时间转换为本地…

批量视频剪辑新选择:一键式按照指定秒数分割视频并轻松提取视频中的音频,让视频处理更高效!

是否经常为大量的视频剪辑工作感到头疼&#xff1f;还在一个个手动分割、提取音频吗&#xff1f;现在&#xff0c;我们为你带来了一款全新的视频批量剪辑神器&#xff0c;让你轻松应对各种视频处理需求&#xff01; 首先&#xff0c;进入媒体梦工厂的主页面&#xff0c;并在板…

后台架构总结

前言 疫情三年&#xff0c;全国各地的健康码成为了每个人的重要生活组成部分。虽然过去一年&#xff0c;但是回想起来任然历历在目。 今天我就通过当时基于小程序的健康码架构&#xff0c;来给大家讲一下如何基于java&#xff0c;springboot等技术来快速搭建一个后台业务系统…

freeRTOS任务通知(1-17)

任务通知简介&#xff1a; def&#xff1a; 任务通知是用来通知任务的&#xff0c;任务控制块中的结构体成员变量ulNotifiedValue就是这个通知值。 任务通知的内存消耗比较小 1&#xff1a; 使用队列&#xff0c;信号量&#xff0c;时间标志组都需要另外创建结构体&#xff…

C++设计模式-创建型设计模式

设计模式 设计模式是什么 设计模式是指在软件开发中&#xff0c;经过验证的&#xff0c;用于解决在特定环境下&#xff0c;重复出现的&#xff0c;特定问题的解决方案&#xff1b;其实就是解决问题的固定套路。但是要慎用设计模式&#xff0c;有一定的工程代码量之后用它比较…

ue引擎游戏开发笔记(29)——实现第三人称角色随手柄力度进行移动

1.需求分析 角色可以随手柄力量大小进行走路和跑步&#xff0c;不动时保持角色停顿。 2.操作实现 1.思路&#xff1a;通过动画蓝图和动画混合实现角色移动和输入的联系。 2.建立动画蓝图和混合空间&#xff1a; 3.在混合空间中对角色移动进行编辑&#xff1a; 4.在蓝图中设定变…

HTML_CSS学习:浮动

一、浮动简介 相关代码&#xff1a; <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>浮动_简介</title><style>div{width: 600px;height: 400px;background-color: #1c80d9;}img{float:…

Java进阶【十三期】:【异常处理】 (抛出捕获异常、自定义异常处理)、处理异常的几种方式 【(File】文件路径操作、File文件处理的综合练习

文章目录 Java进阶【十三期】&#xff1a;异常处理一、异常基本介绍二、编译异常和运行异常三、总结 异常的作用异常的处理方式一、JVM默认的处理方式二、自己处理异常自己 处理的问题 三、总结 Throwable 成员方法抛出异常总结 异常练习自定义异常 FileFile 三个 构造方法File…

【SSM进阶学习系列丨分页篇】PageHelper 分页插件导入集成实践

文章目录 一、说明什么是分页PageHelper介绍 二、导入依赖三、集成Spring框架中四、编写Service五、编写Controller六、编写queryAllByPage页面展示数据 一、说明 什么是分页 ​ 针对分页&#xff0c;使用的是PageHelper分页插件&#xff0c;版本使用的是5.1.8 。 ​ 参考文档…

力扣hot100:543. 二叉树的直径/108. 将有序数组转换为二叉搜索树

一、543. 二叉树的直径 LeetCode&#xff1a;543. 二叉树的直径 二叉树的直径 二叉树的 直径 是指树中任意两个节点之间最长路径的 长度 。 遇到二叉树的问题很容易去直接用求解的目标去定义递归函数。但是仔细考虑&#xff0c;返回树的直径并不能向上传播。因此我们可以拆…

三维球体空间中光线反射模拟与三维点云提取matlab仿真

目录 1.程序功能描述 2.测试软件版本以及运行结果展示 3.核心程序 4.本算法原理 5.完整程序 1.程序功能描述 三维球体空间中光线反射模拟与三维点云提取matlab仿真。设置一个三维的椭球模型&#xff0c;作为墙壁&#xff0c;然后根据光线的反射原理&#xff0c;设计三维空…

Linux内核--设备驱动(四)基础通信接口整理

目录 一、引言 二、I2C ------>2.1、虚拟总线 ------>2.2、I2C适配器序列号指定 ------>2.3、I2C驱动的注册 ------>2.4、I2C设备的创建及注册 ------>2.5、probe 三、I2S 四、DMA ------>4.1、MMU IOMMU 一、引言 本篇文章对于常见通讯接口的内…

华为OD机试 - 小扇和小船的数字游戏 - 二进制(Java 2024 C卷 200分)

华为OD机试 2024C卷题库疯狂收录中&#xff0c;刷题点这里 专栏导读 本专栏收录于《华为OD机试&#xff08;JAVA&#xff09;真题&#xff08;A卷B卷C卷&#xff09;》。 刷的越多&#xff0c;抽中的概率越大&#xff0c;每一题都有详细的答题思路、详细的代码注释、样例测试…

题目:方格取数[Easy]

问题描述&#xff1a; 解题思路&#xff1a; 可以使用动态规划&#xff0c;建立dp[i][j][x]&#xff0c;表示&#xff08;1&#xff0c;1&#xff09;到&#xff08;i&#xff0c;j&#xff09;且其积的余数为x的情况下的方案数。时间复杂度为(n^2) * k。 AC代码&#xff1a; …

零基础学习数据库SQL语句之查询表中数据的DQL语句

是用来查询数据库表的记录的语句 在SQL语句中占有90%以上 也是最为复杂的操作 最为繁琐的操作 DQL语句很重要很重要 初始化数据库和表 USE dduo;create table tb_emp(id int unsigned primary key auto_increment comment ID,username varchar(20) not null unique comment…