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

  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,//0ADD,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.mzph.cn/pingmian/6392.shtml

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

相关文章

初始《stack》《queue》及手搓模拟《stack》《queue》

目录 前言&#xff1a; stack的介绍和使用 stack的介绍&#xff1a; ​编辑stack的使用&#xff1a; ​编辑stack的模拟实现&#xff1a; queue的介绍和使用 queue的介绍&#xff1a; queue的使用: queue的模拟实现: priority_queue的介绍和使用 priority_queue的介绍:…

Hdfs小文件治理策略以及治理经验

小文件是 Hadoop 集群运维中的常见挑战&#xff0c;尤其对于大规模运行的集群来说可谓至关重要。如果处理不好&#xff0c;可能会导致许多并发症。Hadoop集群本质是为了TB,PB规模的数据存储和计算因运而生的。为啥大数据开发都说小文件的治理重要&#xff0c;说HDFS 存储小文件…

08 - 步骤 表输出

简介 表输出&#xff08;Table Output&#xff09;步骤是用于将 Kettle 中的数据写入关系型数据库表的步骤。它允许用户将数据流中的数据插入、更新或删除到目标数据库表中。 使用 场景 我要将处理完的数据流中的sysOrgCode 跟 plateNumber 保存记录到mysql 1、拖拽表输出…

Java Jackson-jr 库使用介绍

介绍 Jackson-jr 是一个轻量级的Java JSON 处理库。这个库被设计用来替代 Jackson 的复杂性。对比 Jackson 的复杂 API&#xff0c;Jackson-jr 的启动速度更快&#xff0c;包大小更小。 虽然Jackson databind&#xff08;如ObjectMapper&#xff09;是通用数据绑定的良好选择…

初学python记录:力扣1235. 规划兼职工作

题目&#xff1a; 你打算利用空闲时间来做兼职工作赚些零花钱。 这里有 n 份兼职工作&#xff0c;每份工作预计从 startTime[i] 开始到 endTime[i] 结束&#xff0c;报酬为 profit[i]。 给你一份兼职工作表&#xff0c;包含开始时间 startTime&#xff0c;结束时间 endTime …

ROS服务器通信

目录 一、角色 二、流程 注意 三、例子描述 四、srv文件 编译配置文件 vscode配置 五、Server.cpp编写例子 编写CMakeList 六、观察server的效果 七、Client编写例子 编写CMakeList 八、观察Client的结果 九、Client优化&#xff08;动态输入&#xff09; 了解argc…

计算机行业AI前沿报告:混合专家模型技术(MoE)

今天分享的是****AI系列深度研究报告&#xff1a;《计算机行业AI前沿报告&#xff1a;混合专家模型技术(MoE)》。&#xff08;报告出品方&#xff1a;中信建投证券&#xff09; 精选内容来源公众&#xff1a;见鹿报告 报告共计: 24页 [报告内容摘要如下] **•核心观点&…

ASP.NET 两种开发模式

1》》WebForm 开发模式 1. 服务器端控件 2. 一般处理程序html静态页Ajax 3. 一般处理程序html模板 如下图 2》》MVC 太复杂的系统&#xff0c;会造成Controller 过复杂。 后来就诞生了 MVP、MVVM等模式

AI大模型探索之路-训练篇12:语言模型Transformer库-Datasets组件实践

系列篇章&#x1f4a5; AI大模型探索之路-训练篇1&#xff1a;大语言模型微调基础认知 AI大模型探索之路-训练篇2&#xff1a;大语言模型预训练基础认知 AI大模型探索之路-训练篇3&#xff1a;大语言模型全景解读 AI大模型探索之路-训练篇4&#xff1a;大语言模型训练数据集概…

FlaUI

FlaUI是一个基于微软UIAutomation技术&#xff08;简称UIA&#xff09;的.NET库&#xff0c;它主要用于对Windows应用程序&#xff08;如Win32、WinForms、WPF、Store Apps等&#xff09;进行自动化UI测试。FlaUI的前身是TestStack.White&#xff0c;由Roemer开发&#xff0c;旨…

Linux平台下muduo网络库源码编译安装与测试,包含boost库的安装与测试!!!!

最近在学习muduo网络库&#xff0c;先来记录一下如何在Linux平台下编译安装以及测试muduo网络库源码。 获取源码 muduo库源码github仓库地址&#xff1a; https://github.com/chenshuo/muduo 在linux系统下&#xff0c;输入 git clone https://github.com/chenshuo/muduo.git…

QT防止自研软件被复制的基本操作(二)

参考一 自研软件为了防止被人任意复制传播&#xff0c;需要设置注册使用模式。基本原理&#xff1a;通过计算机的特异性编号&#xff0c;加上自己的编码&#xff0c;使用加密算法算出一个生成码。 一、计算机的特异性编号 硬盘的编号&#xff1a;最后一块硬盘的编号就行&#…

【简单讲解下npm常用命令】

&#x1f308;个人主页: 程序员不想敲代码啊 &#x1f3c6;CSDN优质创作者&#xff0c;CSDN实力新星&#xff0c;CSDN博客专家 &#x1f44d;点赞⭐评论⭐收藏 &#x1f91d;希望本文对您有所裨益&#xff0c;如有不足之处&#xff0c;欢迎在评论区提出指正&#xff0c;让我们共…

JavaScript 中的 Class 类

&#x1f525; 引言 在ECMAScript 2015&#xff08;ES6&#xff09;中&#xff0c;class 关键字被引入&#xff0c;为JavaScript带来了一种更接近传统面向对象语言的语法糖。类是创建对象的模板&#xff0c;它们封装了数据&#xff08;属性&#xff09;和行为&#xff08;方法&…

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

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

计算机的翻译(编译和链接)过程

&#x1f381;个人主页&#xff1a;我们的五年 &#x1f50d;系列专栏&#xff1a;C语言基本概念 &#x1f337;追光的人&#xff0c;终会万丈光芒 &#x1f389;欢迎大家点赞&#x1f44d;评论&#x1f4dd;收藏⭐文章 目录 &#x1f697;1.翻译环境和运行环境&#xff1…

生信小知识 | 如何快速确定一个物种某一个基因家族全部基因数目

公众号&#xff1a;生信漫谈&#xff0c;获取最新科研信息&#xff01; 生信小知识 | 如何快速确定一个物种某一个基因家族全部基因数目https://mp.weixin.qq.com/s?__bizMzkwNjQyNTUwMw&mid2247486827&idx1&sn9fea85f8d28af3e02570235936a1f535&chksmc0e9e8…

io流,字节流概述

io流概述 io流&#xff1a;输入输出流读写数据的 i 指Input&#xff0c;称为输入流:负责把数据读到内存中去 o指Output&#xff0c;称为输出流:负责写数据出去 io流的分类 按流的方向分为: 输入流和输出流。 按流中数据的最小单位&#xff0c; 分为:字节流&#xff08;适合操作…

展开说说:Android Fragment完全解析-卷三

本文章分析了Fragment的管理器FragmentManager、事务FragmentTransaction 、以及完整的声明周期和动态加载Fragment的原理解析。 1、Fragment管理器 FragmentManager 类负责在应用的 fragment 上执行一些操作&#xff0c;如添加、移除或替换操作&#xff0c;以及将操作添加到…

c#学习基础2

四、复杂数据类型--结构体 1.基本概念 、2.基本语法 结构体一般写在namespace语句块中&#xff1b; 结构体关键字 struct 3.实例 4.结构体的使用 5.访问修饰符 6.结构体的构造函数 7.总结 五、排序初探 1&#xff09;冒泡排序 1.排序的基本概念 2.冒泡排序的基本原理 两…