C++第15周项目4扩展——带姓名的多科成绩单

2024-03-03 10:58

本文主要是介绍C++第15周项目4扩展——带姓名的多科成绩单,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

课程首页地址:http://blog.csdn.net/sxhelijian/article/details/7910565


【项目4-多科成绩单】用二维数组score[][4]保存同学们的高数、英语、C++成绩及总成绩(在此假设学生的学号为整型的连续值,用数组的行下标作学号)。在此基础上,完成下面的操作:
(1)设计输入成绩的函数,输入3科成绩后可以自动求出总分,并将数据全保存到数组中;
(2)输出各门课及总分的最高成绩、最低成绩、平均成绩和成绩的标准偏差;
(3)输出考得总分最高、最低同学的人数及对应的学号。
要求:学生人数num在main()函数中输入,score[][4]数组也是main()函数的局部变量,最好将其他功能也设计成函数,使main()函数尽可能地简单。
【项目4扩展(选做)-带姓名的多科成绩单】增加用数组string name[]表示同学们的姓名,使姓名与成绩的下标保持一致(例如name[1]和score[1][0]、score[1][1]、score[1][2]和score[1][3]表示同一位同学的数据)。据此,将项目4中的第(3)项任务改为输出总分最高的同学的姓名。
扩展题参考解答:

#include<iostream>
#include<cmath>
#include<string>
using namespace std;
double max(double s[][4],int n,int i); //求第i门课的最高成绩,i=3时是总分,下类似
double min(double s[][4],int n,int i);
output_result(string name[],double s[][4],int n);int main()
{int i,num;string temp;double score[100][4]; //设一个班最多100人,实际按输入来string name[100];cout<<"输入学生人数:";cin>>num;//(1)输入成绩并求出总分cout<<"输入学生成绩(按姓名、高数、英语、C++的顺序依次输入:)"<<endl;for(i=0;i<num;++i){cin>>name[i]>>score[i][0]>>score[i][1]>>score[i][2];score[i][3]=score[i][0]+score[i][1]+score[i][2];}cout<<"输入的学生成绩为:"<<endl;cout<<"学号\t姓名\t高数\t英语\tC++\t总分"<<endl;for(i=0;i<num;++i){cout<<i<<'\t'<<name[i]<<'\t';cout<<score[i][0]<<'\t';cout<<score[i][1]<<'\t';cout<<score[i][2]<<'\t';cout<<score[i][3]<<endl;}//(3)输出考得总分最高、最低同学的人数及对应的学号。output_result(name,score,num);return 0;
}//求第i门课的最高成绩,i=3时是总分,下类似
double max(double s[][4],int n,int j)
{double m=s[0][j];for(int i=1;i<n;++i)if (m<s[i][j]) m=s[i][j];return m;
}
double min(double s[][4],int n,int j)
{double m=s[0][j];for(int i=1;i<n;++i)if (m>s[i][j]) m=s[i][j];return m;
}
//输出考得总分最高、最低同学的人数及对应的学号。
output_result(string name[],double s[][4],int n)
{double m=max(s,n,3);int i,c=0;bool first=true;cout<<"总分最高分为"<<m;for(i=0;i<n;++i){if(s[i][3]==m)//直接用s[i][3]==m可能会因精度而错误++c;}cout<<",有"<<c<<"人达到最高分,他们的姓名是:";for(i=0;i<n;++i){if(s[i][3]==m)if(first){cout<<name[i];first=false;}else{cout<<"、"<<name[i];}}cout<<endl;//关于最低成绩m=min(s,n,3);c=0;first=true;cout<<"总分最低分为"<<m;for(i=0;i<n;++i){if(s[i][3]==m) ++c;}cout<<",有"<<c<<"人达到最低分,他们的姓名是:";for(i=0;i<n;++i){if(s[i][3]==m)if(first){cout<<name[i];first=false;}else{cout<<"、"<<name[i];}}cout<<endl;
}


这篇关于C++第15周项目4扩展——带姓名的多科成绩单的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/769411

相关文章

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

如何用Docker运行Django项目

本章教程,介绍如何用Docker创建一个Django,并运行能够访问。 一、拉取镜像 这里我们使用python3.11版本的docker镜像 docker pull python:3.11 二、运行容器 这里我们将容器内部的8080端口,映射到宿主机的80端口上。 docker run -itd --name python311 -p

【C++ Primer Plus习题】13.4

大家好,这里是国中之林! ❥前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。有兴趣的可以点点进去看看← 问题: 解答: main.cpp #include <iostream>#include "port.h"int main() {Port p1;Port p2("Abc", "Bcc", 30);std::cout <<

csu 1446 Problem J Modified LCS (扩展欧几里得算法的简单应用)

这是一道扩展欧几里得算法的简单应用题,这题是在湖南多校训练赛中队友ac的一道题,在比赛之后请教了队友,然后自己把它a掉 这也是自己独自做扩展欧几里得算法的题目 题意:把题意转变下就变成了:求d1*x - d2*y = f2 - f1的解,很明显用exgcd来解 下面介绍一下exgcd的一些知识点:求ax + by = c的解 一、首先求ax + by = gcd(a,b)的解 这个

C++包装器

包装器 在 C++ 中,“包装器”通常指的是一种设计模式或编程技巧,用于封装其他代码或对象,使其更易于使用、管理或扩展。包装器的概念在编程中非常普遍,可以用于函数、类、库等多个方面。下面是几个常见的 “包装器” 类型: 1. 函数包装器 函数包装器用于封装一个或多个函数,使其接口更统一或更便于调用。例如,std::function 是一个通用的函数包装器,它可以存储任意可调用对象(函数、函数

C++11第三弹:lambda表达式 | 新的类功能 | 模板的可变参数

🌈个人主页: 南桥几晴秋 🌈C++专栏: 南桥谈C++ 🌈C语言专栏: C语言学习系列 🌈Linux学习专栏: 南桥谈Linux 🌈数据结构学习专栏: 数据结构杂谈 🌈数据库学习专栏: 南桥谈MySQL 🌈Qt学习专栏: 南桥谈Qt 🌈菜鸡代码练习: 练习随想记录 🌈git学习: 南桥谈Git 🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈�

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

06 C++Lambda表达式

lambda表达式的定义 没有显式模版形参的lambda表达式 [捕获] 前属性 (形参列表) 说明符 异常 后属性 尾随类型 约束 {函数体} 有显式模版形参的lambda表达式 [捕获] <模版形参> 模版约束 前属性 (形参列表) 说明符 异常 后属性 尾随类型 约束 {函数体} 含义 捕获:包含零个或者多个捕获符的逗号分隔列表 模板形参:用于泛型lambda提供个模板形参的名

科研绘图系列:R语言扩展物种堆积图(Extended Stacked Barplot)

介绍 R语言的扩展物种堆积图是一种数据可视化工具,它不仅展示了物种的堆积结果,还整合了不同样本分组之间的差异性分析结果。这种图形表示方法能够直观地比较不同物种在各个分组中的显著性差异,为研究者提供了一种有效的数据解读方式。 加载R包 knitr::opts_chunk$set(warning = F, message = F)library(tidyverse)library(phyl