习题:将person类作为学生类student的基类,派生一个学生类,其中数据成员有学号、姓名、年龄、3门课程的成绩,以及若干成员函数。

本文主要是介绍习题:将person类作为学生类student的基类,派生一个学生类,其中数据成员有学号、姓名、年龄、3门课程的成绩,以及若干成员函数。,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 完整题干:

将person类作为学生类student的基类,派生一个学生类,其中数据成员有学号、姓名、年龄、3门课程的成绩,以及若干成员函数。并利用这个类建立一个对象数组。(1)求第一门课的平均成绩;(2)找出有两门以上课程不及格的学生,输出他们的学号和全部课程成绩和平均成绩;(3)找出平均成绩在90分以上或全部课程成绩在85分以上的学生。分别编3个函数实现以上三个要求。

要求:

(1)使用构造函数实现对数据的输入。

(2)以上三个要求必须用成员函数实现。

(3)在头文件中完成类的声明,在.cpp中完成类的实现,在主文件(.cpp)中完成主函数编写。

个人答案:

#include<iostream>
#include<string>
using namespace std;
class person
{
public:};
class Student:public person
{
public:Student(string, int, int, int, int,int);Student();void f(Student*p);void y(Student *p);void h(Student* p);
protected:string name; int xuehao; int zheng;  int math; int zhuan; int age;};
void Student::f(Student *p)
{int sum = 0;for (int i = 0; i < 10; i++){sum = (*(p+i)).zheng+ sum;}cout << "第一科政治平均成绩为:" << sum / 10.0 << endl;
}
void Student::y(Student*p)
{for (int i = 0; i < 10; i++) {int sum = 0;sum = ((*(p + i)).zheng + (*(p + i)).math + (*(p + i)).zhuan) / 3.0;if (((*(p + i)).zheng < 60 && (*(p + i)).math < 60) || ((*(p + i)).zheng < 60 && (*(p + i)).zhuan < 60) || ((*(p + i)).math < 60 && (*(p + i)).zhuan < 60)){cout << "不及格的学生:" << (*(p + i)).xuehao;cout << "政治:" << (*(p + i)).zheng << "数学:" << (*(p + i)).math << "专业课:" << (*(p + i)).zhuan << "平均成绩:" << sum << endl;}}
}
void Student::h(Student* p)
{for (int i = 0; i < 10; i++) {int sum = 0;sum = ((*(p + i)).zheng + (*(p + i)).math + (*(p + i)).zhuan) / 3.0;if (((*(p + i)).zheng > 85 && (*(p + i)).math > 85 && (*(p + i)).zhuan > 85) || (sum > 90))cout << "优秀学生:" << (*(p + i)).name << endl;}
}
Student::Student(string n, int x, int z, int m, int a,int g)
{name = n;xuehao = x;zheng = z;math = m;zhuan = a;age = g;
}
Student::Student()
{name = " ";xuehao =0;zheng = 0;math = 0;zhuan = 0;age = 0;
}
int main()
{Student a[10] ={Student("白雪华",20110901,89,90,90,18),Student("韩姣姣",20110902,88,90,90,19),Student("张璐璐",20110903,95,90,90,18),Student("张清晨",20110904,78,90,90,19),Student("张博涵",20110902,79,90,90,20),Student("朱玉玲",20110902,45,25,90,20),Student("姜健康",20110902,75,90,90,18),Student("王龙洋",20110902,88,55,90,17),Student("马传皓",20110902,88,95,90,19),Student("张振龙",20110902,95,98,90,19),};Student t;t.f(a);t.y(a);t.h(a);system("pause");return 0;
}

结果:

 

这篇关于习题:将person类作为学生类student的基类,派生一个学生类,其中数据成员有学号、姓名、年龄、3门课程的成绩,以及若干成员函数。的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Rust中的BoxT之堆上的数据与递归类型详解

《Rust中的BoxT之堆上的数据与递归类型详解》本文介绍了Rust中的BoxT类型,包括其在堆与栈之间的内存分配,性能优势,以及如何利用BoxT来实现递归类型和处理大小未知类型,通过BoxT,Rus... 目录1. Box<T> 的基础知识1.1 堆与栈的分工1.2 性能优势2.1 递归类型的问题2.2

Python使用Pandas对比两列数据取最大值的五种方法

《Python使用Pandas对比两列数据取最大值的五种方法》本文主要介绍使用Pandas对比两列数据取最大值的五种方法,包括使用max方法、apply方法结合lambda函数、函数、clip方法、w... 目录引言一、使用max方法二、使用apply方法结合lambda函数三、使用np.maximum函数

Python itertools中accumulate函数用法及使用运用详细讲解

《Pythonitertools中accumulate函数用法及使用运用详细讲解》:本文主要介绍Python的itertools库中的accumulate函数,该函数可以计算累积和或通过指定函数... 目录1.1前言:1.2定义:1.3衍生用法:1.3Leetcode的实际运用:总结 1.1前言:本文将详

Redis的数据过期策略和数据淘汰策略

《Redis的数据过期策略和数据淘汰策略》本文主要介绍了Redis的数据过期策略和数据淘汰策略,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录一、数据过期策略1、惰性删除2、定期删除二、数据淘汰策略1、数据淘汰策略概念2、8种数据淘汰策略

轻松上手MYSQL之JSON函数实现高效数据查询与操作

《轻松上手MYSQL之JSON函数实现高效数据查询与操作》:本文主要介绍轻松上手MYSQL之JSON函数实现高效数据查询与操作的相关资料,MySQL提供了多个JSON函数,用于处理和查询JSON数... 目录一、jsON_EXTRACT 提取指定数据二、JSON_UNQUOTE 取消双引号三、JSON_KE

MySQL数据库函数之JSON_EXTRACT示例代码

《MySQL数据库函数之JSON_EXTRACT示例代码》:本文主要介绍MySQL数据库函数之JSON_EXTRACT的相关资料,JSON_EXTRACT()函数用于从JSON文档中提取值,支持对... 目录前言基本语法路径表达式示例示例 1: 提取简单值示例 2: 提取嵌套值示例 3: 提取数组中的值注意

Python给Excel写入数据的四种方法小结

《Python给Excel写入数据的四种方法小结》本文主要介绍了Python给Excel写入数据的四种方法小结,包含openpyxl库、xlsxwriter库、pandas库和win32com库,具有... 目录1. 使用 openpyxl 库2. 使用 xlsxwriter 库3. 使用 pandas 库

SpringBoot定制JSON响应数据的实现

《SpringBoot定制JSON响应数据的实现》本文主要介绍了SpringBoot定制JSON响应数据的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们... 目录前言一、如何使用@jsonView这个注解?二、应用场景三、实战案例注解方式编程方式总结 前言

使用Python在Excel中创建和取消数据分组

《使用Python在Excel中创建和取消数据分组》Excel中的分组是一种通过添加层级结构将相邻行或列组织在一起的功能,当分组完成后,用户可以通过折叠或展开数据组来简化数据视图,这篇博客将介绍如何使... 目录引言使用工具python在Excel中创建行和列分组Python在Excel中创建嵌套分组Pyt

在Rust中要用Struct和Enum组织数据的原因解析

《在Rust中要用Struct和Enum组织数据的原因解析》在Rust中,Struct和Enum是组织数据的核心工具,Struct用于将相关字段封装为单一实体,便于管理和扩展,Enum用于明确定义所有... 目录为什么在Rust中要用Struct和Enum组织数据?一、使用struct组织数据:将相关字段绑