编写一个程序,已有若干学生的数据,包括学号、姓名、成绩,要求输出这些学生的数据并计算出学生人数和平均成绩(要求将学生人数和总成绩用静态数据成员表示)。

时间: 2023-06-05 22:47:03 浏览: 308
以下是一个示例程序,实现了上述要求: ```c++ #include <iostream> #include <string> using namespace std; class Student { public: Student(int id, string name, double score) { m_id = id; m_name = name; m_score = score; s_count++; s_totalScore += score; } void print() { cout << "学号:" << m_id << ",姓名:" << m_name << ",成绩:" << m_score << endl; } static int getCount() { return s_count; } static double getAverageScore() { return s_totalScore / s_count; } private: int m_id; string m_name; double m_score; static int s_count; static double s_totalScore; }; int Student::s_count = 0; double Student::s_totalScore = 0; int main() { Student s1(1, "张三", 80); Student s2(2, "李四", 90); Student s3(3, "王五", 85); s1.print(); s2.print(); s3.print(); cout << "学生人数:" << Student::getCount() << endl; cout << "平均成绩:" << Student::getAverageScore() << endl; return 0; } ``` 程序中定义了一个`Student`类,包含学号、姓名、成绩等属性,以及静态数据成员`s_count`和`s_totalScore`,分别表示学生人数和总成绩。在`Student`类的构造函数中,每创建一个学生对象,就将`s_count`加1,将`s_totalScore`加上该学生的成绩。在`print`函数中,输出学生的信息。在`getCount`和`getAverageScore`函数中,分别返回`s_count`和`s_totalScore / s_count`,即学生人数和平均成绩。 在`main`函数中,创建了三个学生对象`s1`、`s2`、`s3`,并分别输出它们的信息。最后,调用`Student`类的静态函数`getCount`和`getAverageScore`,输出学生人数和平均成绩。

相关推荐

用c语言编写1. 学生档案记录录入:录入学生的学号、姓名、性别、年龄和总绩点,以记录形式保存在 文件末尾。注意:录入第一个学生的记录时要创建文件,录入其他学生的记录时只需要 打开已经创建的文件就可以 2. 学生档案记录修改:允许用户选择并从文件中读取要修改的学生记录,修改指定的记录 后,能将改记录写回文件中原来的位置 3. 学生档案记录删除:允许用户选择要删除的学生记录,告诉用户准备删除哪个记录,获 得用户确认后从文件中删除这个记录。注意:删除一个记录后,后面的记录都得往前挪! 4. 学生记录排序:对保存在文件中的记录按学号排序,排序后的记录仍写回原来的文件 5. 其他功能:其他您以为适当的功能,比如按姓名、绩点排序,统计平均年龄和绩点,按 姓名、年龄查找并显示学生档案资料 程序设计提示: 1. 设计文件数据结构:设计文件的存储结构,将每个学生的学号、姓名、性别、年龄和总 绩点保存为一个记录,以便进行随机存取。例如:学号 12 个字节,姓名 8 个字节,性 别 2 个字节,年龄 2 个字节,总绩点 3 个字节,记起来一个学生的记录总共需要 27 个 字节,记录的长度就是 27 个字节 2. 根据所要保存的学生档案记录内容(学号、姓名、性别、年龄和总绩点),设计结构体 数据类型,结合结构体数组的运用实现文件记录的读写访问 3. 将以上各功能都设计成独立的函数,在 main 函数中显示一个菜单,让用户选择要执行 的功能,然后转而执行相应的函数 4. 如果可能,在学生记录中增加若干需要登记的资料,例如:住址、专业、班级号等

/*有n个学生,每个学生的数据包括学号,C语言程序设计课程的平时成绩和期末考试成绩,测试数据已在主函数中,要求按平时成绩占30%,期末成绩占70%计算总评成绩, 并将总评成绩低于90分,且高于等于80分的同学的等级确定为"良好",并将这些同学的对应信息存放在结构体数组h中,人数通过函数返回值得到,输出相应的信息。 请勿改动main函数和其他函数中的任何内容,仅在函数fun的花括号中注释语句之间填入所编写的若干语句。*/ #include <stdio.h> #include<string.h> #include<stdlib.h> #define N 100 typedef struct { char num[10];/*学号*/ int s1;/*期末成绩*/ int s2;/*平时成绩*/ float sum; /*总评*/ char level[10]; /*等级*/ } STU; int fun (STU a[],int n,STU h[]) { /************Begin************/ /************End**************/ } int main() { STU s[N]={{"GA05",85,76},{"GA03",76,90},{"GA02",69,90},{"GA04",85,56},{"GA01",91,95}, {"GA07",72,80},{"GA08",64,45}, {"GA06",87,98},{"GA015",85,86},{"GA013",91,97}},h[N]; int i,k,n=10; FILE *out,*in; k=fun(s,n,h); printf("There are :\n"); for(i=0;i<k;i++) printf("%s %d %d %.2f %s\n",h[i].num,h[i].s1,h[i].s2,h[i].sum,h[i].level); /******************************/ in=fopen("in68.dat","r"); out=fopen("out68.dat","w"); i=0; while(!feof(in)) { fscanf(in,"%s %d %d",s[i].num,&s[i].s1,&s[i].s2); i++; } n=i; k=fun(s,n,h); for(i=0;i<k;i++) fprintf(out,"%s %d %d %.2f %s\n",h[i].num,h[i].s1,h[i].s2,h[i].sum,h[i].level); fclose(out); fclose(in); /******************************/ system("pause"); return 0; }

最新推荐

recommend-type

c语言作业——学生成绩统计.docx

(1)学生基本信息(学号、姓名、…….)录入; (2)学生成绩录入; (3)统计学生成绩分布情况(每个分数段人数); (4)查找最高分、最低分;计算学生成绩均值和方差;并输出这四个结果; (5)判断成绩是否服从...
recommend-type

网络编程网络编程网络编程

网络编程网络编程网络编程网络编程
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

用 Python 画一个可以动的爱心

好的,我可以帮助您使用Python来绘制一个动态的爱心。您可以使用turtle库来实现。以下是实现代码: ```python import turtle import math # 设置画布和画笔 canvas = turtle.Screen() canvas.bgcolor("black") pencil = turtle.Turtle() pencil.speed(0) pencil.color("red", "pink") pencil.pensize(3) # 定义爱心函数 def draw_love(heart_size, x_offset=0, y_offset=0):
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。
recommend-type

"互动学习:行动中的多样性与论文攻读经历"

多样性她- 事实上SCI NCES你的时间表ECOLEDO C Tora SC和NCESPOUR l’Ingén学习互动,互动学习以行动为中心的强化学习学会互动,互动学习,以行动为中心的强化学习计算机科学博士论文于2021年9月28日在Villeneuve d'Asq公开支持马修·瑟林评审团主席法布里斯·勒菲弗尔阿维尼翁大学教授论文指导奥利维尔·皮耶昆谷歌研究教授:智囊团论文联合主任菲利普·普雷教授,大学。里尔/CRISTAL/因里亚报告员奥利维耶·西格德索邦大学报告员卢多维奇·德诺耶教授,Facebook /索邦大学审查员越南圣迈IMT Atlantic高级讲师邀请弗洛里安·斯特鲁布博士,Deepmind对于那些及时看到自己错误的人...3谢谢你首先,我要感谢我的两位博士生导师Olivier和Philippe。奥利维尔,"站在巨人的肩膀上"这句话对你来说完全有意义了。从科学上讲,你知道在这篇论文的(许多)错误中,你是我可以依
recommend-type

实现实时监控告警系统:Kafka与Grafana整合

![实现实时监控告警系统:Kafka与Grafana整合](https://imgconvert.csdnimg.cn/aHR0cHM6Ly9tbWJpei5xcGljLmNuL21tYml6X2pwZy9BVldpY3ladXVDbEZpY1pLWmw2bUVaWXFUcEdLT1VDdkxRSmQxZXB5R1lxaWNlUjA2c0hFek5Qc3FyRktudFF1VDMxQVl3QTRXV2lhSWFRMEFRc0I1cW1ZOGcvNjQw?x-oss-process=image/format,png) # 1.1 Kafka集群架构 Kafka集群由多个称为代理的服务器组成,这
recommend-type

已知n个人(以编号0,1,2,3...n-1分别表示)围坐在一张圆桌周围。从编号为0的人开始报数1,数到m的那个人出列;他的下一个人又从1开始报数,数到m+1的那个人又出列(每次报数值加1);依此规律重复下去,直到圆桌周围的人全部出列。用递归方法解决

这个问题可以使用递归方法解决。下面是一个思路: 1. 定义一个函数,接收三个参数:n、m、i,表示还剩下n个人,每次数到m时出列,当前报数的人是i; 2. 如果n=1,返回i,即最后留下的那个人的编号; 3. 否则,计算出下一个出列的人的编号j,通过递归调用函数解决n-1个人的问题,其结果为k; 4. 如果k < j,即当前i之后出列的人的编号为k,需要将k转换为在i之前出列的编号,返回值为 k+(n-1); 5. 如果k>=j,即当前i之后出列的人的编号为k,返回值为 k-(j-1); 下面是对应的Python代码: ```python def josephus(n, m, i):