技术标签: c语言查找指定编号学生的成绩
#include
#include
#include
#include
#include
using namespace std;
struct Student{
char id[20];
char name[20];
double chinese;
double math;
double english;
double average;
};
int totalrecords = 0;
struct Student student[1001];
void fun01(){
printf("学号 姓名 语文 数学 英语\n");
for(int i = 0; i < totalrecords; i++){
printf("%s\t%s\t%.1lf\t%.1lf\t%.1lf\n", student[i].id, student[i].name, student[i].chinese, student[i].math, student[i].english);
}
}
void fun02(){
printf("请输入学生学号,姓名,语文成绩,数学成绩,英语成绩,以空格隔开:\n");
char id[20];
char name[20];
double chinese;
double math;
double english;
scanf("%s %s %lf %lf %lf", id, name, &chinese, &math, &english);
strcpy(student[totalrecords].id, id);
strcpy(student[totalrecords].name, name);
student[totalrecords].chinese = chinese;
student[totalrecords].math = math;
student[totalrecords].english = english;
totalrecords++;
printf("信息录入成功!\n");
}
void fun03(){
for(int i = 0; i < totalrecords; i++){
student[i].average = (student[i].chinese + student[i].math + student[i].english) / 3;
}
printf("计算结果为:\n");
printf("学号 姓名 语文 数学 英语 平均成绩\n");
for(int i = 0; i < totalrecords; i++){
printf("%s\t%s\t%.1lf\t%.1lf\t%.1lf\t%.1lf\n", student[i].id, student[i].name, student[i].chinese, student[i].math, student[i].english, student[i].average);
}
}
void fun04(){
printf("请输入待修改学生学号:\n");
char id01[20];
scanf("%s", id01);
char id[20];
char name[20];
double chinese;
double math;
double english;
for(int i = 0; i < totalrecords; i++){
if(strcmp(id01, student[i].id) == 0){
printf("请输入修改后的学生学号,姓名,语文成绩,数学成绩,英语成绩,以空格隔开以空格隔开:\n");
scanf("%s %s %lf %lf %lf", id, name, &chinese, &math, &english);
//赋值给结构体数组
strcpy(student[i].id, id);
strcpy(student[i].name, name);
student[i].chinese = chinese;
student[i].math = math;
student[i].english = english;
printf("修改成功!\n");
return ;
}
}
printf("查找失败!请重新输入!\n");
}
void fun05(){
printf("--1.学号--2.姓名--\n");
printf("请输入编号(1-2),按编号指定字段查询:");
int pos;
scanf("%d", &pos);
printf("请输入字段值:\n");
char str[100];
switch (pos){
case 1: {
scanf("%s", str);
//遍历数组,查询到符合要求的就输出
printf("查询到的结果为:\n");
for(int i = 0; i < totalrecords; i++){
if(strcmp(str, student[i].id) == 0){
printf("%s\t%s\t%.1lf\t%.1lf\t%.1lf\n", student[i].id, student[i].name, student[i].chinese, student[i].math, student[i].english);
}
}
}; break;
case 2: {
scanf("%s", str);
//遍历数组,查询到符合要求的就输出
printf("查询到的结果为:\n");
for(int i = 0; i < totalrecords; i++){
if(strcmp(str, student[i].name) == 0){
printf("%s\t%s\t%.1lf\t%.1lf\t%.1lf\n", student[i].id, student[i].name, student[i].chinese, student[i].math, student[i].english);
}
}
}; break;
default:printf("error\n");
}
}
void fun06(){
//先将平均成绩计算出来
for(int i = 0; i < totalrecords; i++){
student[i].average = (student[i].chinese + student[i].math + student[i].english) / 3;
}
printf("请输入一个分数,系统将查出所有平均成绩大于此分数的学生信息:\n");
double score;
scanf("%lf", &score);
for(int i = 0; i < totalrecords; i++){
if(student[i].average > score){
printf("%s\t%s\t%.1lf\t%.1lf\t%.1lf\t%.1lf\n", student[i].id, student[i].name, student[i].chinese, student[i].math, student[i].english, student[i].average);
}
}
}
void fun07(){
//先将平均成绩计算出来
for(int i = 0; i < totalrecords; i++){
student[i].average = (student[i].chinese + student[i].math + student[i].english) / 3;
}
printf("--1.降序--2.升序--\n");
printf("请输入编号(1-2),按指定方式排序:");
int pos;
scanf("%d", &pos);
Student tmp;
switch (pos){
case 1: {
for(int i = 0; i < totalrecords; i++){
for(int j = 0; j < totalrecords - i - 1; j++){
if(student[j].average < student[j+1].average){
tmp = student[j+1];//结构体允许整体赋值
student[j+1] = student[j];
student[j] = tmp;
}
}
}
printf("学号 姓名 语文 数学 英语 平均成绩\n");
for(int i = 0; i < totalrecords; i++){
printf("%s\t%s\t%.1lf\t%.1lf\t%.1lf\t%.1lf\n", student[i].id, student[i].name, student[i].chinese, student[i].math, student[i].english, student[i].average);
}
}; break;
case 2: {
for(int i = 0; i < totalrecords; i++){
for(int j = 0; j < totalrecords - i - 1; j++){
if(student[j].average > student[j+1].average){
tmp = student[j+1];//结构体允许整体赋值
student[j+1] = student[j];
student[j] = tmp;
}
}
}
printf("学号 姓名 语文 数学 英语 平均成绩\n");
for(int i = 0; i < totalrecords; i++){
printf("%s\t%s\t%.1lf\t%.1lf\t%.1lf\t%.1lf\n", student[i].id, student[i].name, student[i].chinese, student[i].math, student[i].english, student[i].average);
}
}; break;
default:printf("error\n");
}
}
void fun08(){
FILE *fp;//文件指针
int i;
fp=fopen("C:\\Users\\larry\\Desktop\\stu.txt","w");/*以只在文件末尾写的方式打开文件*/
for(i = 0; i < totalrecords; i++)
{
fprintf(fp, "%s %s %.1lf %.1lf %.1lf", student[i].id, student[i].name, student[i].chinese, student[i].math, student[i].english);
fprintf(fp, "\n");
}
fclose(fp);
printf("已完成保存!\n");
}
void fun09(){
int a;
printf("即将退出系统,是否保存(1/0)?\n");
scanf("%d", &a);
if(a == 1){
fun08();
printf("欢迎下次使用!\n");
exit(0);
}else{
printf("数据未保存,已成功退出,欢迎下次使用!\n");
exit(0);
}
}
int main(){
char pwd[100];
printf("请输入密码:\n");
scanf("%s", pwd);
if(strcmp(pwd, "0000") == 0){
printf("********************************************\n");
printf("********************************************\n");
printf("**************学生成绩管理系统**************\n");
printf("********************************************\n");
printf("******1.所有记录*********2.学生信息录入*****\n");
printf("********************************************\n");
printf("******3.平均成绩计算*****4.信息修改*********\n");
printf("********************************************\n");
printf("******5.信息查询*********6.成绩统计*********\n");
printf("********************************************\n");
printf("******7.成绩排序*********8.信息存盘*********\n");
printf("********************************************\n");
printf("***************0.退出系统*******************\n");
printf("********************************************\n");
printf("********************************************\n");
printf("********************************************\n");
int flag;
while(true){
printf("请输入操作编号,回车键结束:");
scanf("%d", &flag);
switch (flag){
case 1: fun01(); break;
case 2: fun02(); break;
case 3: fun03(); break;
case 4: fun04(); break;
case 5: fun05(); break;
case 6: fun06(); break;
case 7: fun07(); break;
case 8: fun08(); break;
case 0: fun09(); break;
default:printf("error\n");
}
}
return 0;
} else{
printf("密码错误!");
}
return 0;
}
一键复制
编辑
Web IDE
原始数据
按行查看
历史
文章浏览阅读1.5w次,点赞35次,收藏385次。自己在网上找的开源项目,比较好分享给大家热门开源项目(包含小四轴、智能手环、光立方、智能车、防丢器等项目)号外!号外!(搞四轴,有这套就足够了!)科研级别的小四轴STM32F4芯片支持WIFI且android手机控制自适应控制就是牛掰!该飞机面向有科研和强烈学习意向的小伙伴们使用,如果只是想玩的话你肯定不会喜欢这套四轴的,主要设计思想是提供一个高性能的控制和姿态算法验证平台,因此..._本科毕业设计拿别人的开源代码修改
文章浏览阅读1w次,点赞2次,收藏26次。QQ 1274510382Wechat JNZ_aming商业联盟 QQ群538250800技术搞事 QQ群599020441解决方案 QQ群152889761加入我们 QQ群649347320共享学习 QQ群674240731纪年科技aming网络安全 ,深度学习,嵌入式,机器强化,生物智能,生命科学。叮叮叮:产品已上线 —>关注 官方-微信公众号——济南纪年信息科技有限公司民生项目:商城加盟/娱乐交友/创业商圈/外包兼职开发-项目发布/安全项目:态势感.._ruoyi java17
文章浏览阅读9k次,点赞2次,收藏3次。 当利用Console口为交换机设置好IP地址信息并启用HTTP服务后,即可通过支持JAVA的Web浏览器访问交换机,并可通过Web通过浏览器修 改交换机的各种参数并对交换机进行管理。事实上,通过Web界面,可以对交换机的许多重要参数进行修改和设置,并可实时查看交换机的运行状态。不过在利用 Web浏览器访问交换机之前,应当确认已经做好以下准备工作:·在用于管理的计算机中安装T..._思科交换机2960s有web配置吗
文章浏览阅读2.5w次,点赞2次,收藏6次。报错信息: [2018-09-09 20:33:12] ERROR - file: tracker_proto.c, line: 48, server: 127.0.0.1:22122, response status 2 != 0 [2018-09-09 20:33:12] ERROR - file: tracker_proto.c, line: 48, server: 127.0.0.1:..._error - file: tracker_proto.c, line: 48, server: 172.17.0.1:22122, response
文章浏览阅读3.9k次。使用matplotlib显示图片(《深度学习入门:基于Python的理论与实现》实践笔记)一、安装matplotlib库二、导入matplotlib.pyplot库和matplotlib.image库里的imread函数三、实例:显示图片一、安装matplotlib库在命令行使用下面的命令即可:pip install matplotlib二、导入matplotlib.pyplot库和matplotlib.image库里的imread函数在程序开头使用:import matplotlib.pyp_matplotlib展示图片
文章浏览阅读1.2k次。基本信息 用户单位:某应用软件研发企业 用户规模:100人以上 组织过程水平:中等 CMMI评审等级:无 Subversion使用时间:1年 客户需求 由于公司每次向新客户提交软件的时候都需要派出一个小规模的团队到客户现场进行一段时间的软件定制和维护。此外,老客户系统的重大升级和功能扩展也需要一个小团队在客户现场进行一段时间的开发。因此,异地开发的配置管理就是一_开发去客户现场的案例
文章浏览阅读3.2k次。一定时宽的语音信号,其能量的大小随时间有明显的变化。清音段能量比浊音段小得多。短时过零数也可用于语音信号分析中,发浊音时,其语音能量约集中于3kHz以下,而发清音时,多数能量出现在较高频率上。可认为浊音时具有较低的平均过零数,而清音时具有较高的平均过零数,故对一短时语音段计算其短时平均能量及短时平均过零数,就可以区分其中的清音段和浊音段,从而可判别句中清、浊音转变时刻,声母韵母的分界以及无声与有声的分界。这在语音识别中有重要意义。自己编写的matlab代码,对一段语音,取帧长为240个点,计算其平均能_matlab求语音信号短时过零率的函数
默认情况下,在Ubuntu上,sudo组的成员被授予sudo访问权限。如果您希望新创建的用户具有管理权限,需要将将用户添加到sudo组。命令将向你询问一系列的问题。密码是必需的,其他字段都是可选的。最后,输入Y确认信息是否正确。执行完上述步骤后需要重启ssh服务,否则新创建的用户连接服务器时会出现。
文章浏览阅读1.7k次。组织战略是组织实施各级项目管理,包括项目组合管理、项目集管理和项目管理的基础。只有从组织战略的高度来思考,思考各个层次项目管理在组织中的位置,才能够理解各级项目管理在组织战略实施中的作用。同时战略管理也为项目管理提供了具体的目标和依据,各级项目管理都需要与组织的战略保持一致。..._项目组织的具体形态的是战略管理层
文章浏览阅读1k次。目录基本统计量色彩空间变换亮度变换函数白平衡图像过曝的评价指标多视影像因曝光条件不一而导致色彩差异,人眼可以快速区分影像质量,如何利用图像信息辅助算法判断影像优劣。基本统计量灰度均值方差梯度均值方差梯度幅值直方图图像熵p·log(p)色彩空间变换RGB转单通道灰度图像 mean = 225.7 stddev = 47.5mean = 158.5 stddev = 33.2转灰度梯度域gradMean = -0.0008297 / -0.000157461gr_图像颜色质量评价
文章浏览阅读1.4k次。Simpson's rule for numerical integrationZ = SIMPS(Y) computes an approximation of the integral of Y via the Simpson's method (with unit spacing). To compute the integral for spacing different from one..._matlab利用幸普生计算积分
文章浏览阅读1.2w次,点赞28次,收藏61次。Hugging face 资源很不错,可是国内下载速度很慢,动则GB的大模型,下载很容易超时,经常下载不成功。很是影响玩AI的信心。经过多次测试,终于搞定了下载,即使超时也可以继续下载。真正实现下载无忧!究竟如何实现?且看本文分解。_huggingface_hub