《C++语言基础》实践项目——多重继承

返回:贺老师课程教学链接

【项目1 - 教师兼干部类】
分别定义Teacher(教师)类和Cadre(干部)类,采用多重继承方式由这两个类派生出新类Teacher_Cadre(教师兼干部)。要求: 
(1)在两个基类中都包含姓名、年龄、性别、地址、电话等数据成员。 
(2)在Teacher类中还包含数据成员title(职称),在Cadre类中还包含数据成员post(职务),在Teacher_Cadre类中还包含数据成员wages(工资)。 
(3)对两个基类中的姓名、年龄、性别、地址、电话等数据成员用相同的名字,在引用这些数据成员时,指定作用域。 
(4)在类体中声明成员函数,在类外定义成员函数。 
(5)在派生类Teacher_Cadre的成员函数show中调用Teacher类中的display函数,输出姓名、年龄、性别、职称、地址、电话,然后再用cout语句输出职务与工资。

[参考解答]

【项目2 - 摩托车继承自行车和机动车】
在下面一段类的定义中,自行车类的虚基类为车辆类,机动车类的虚基类也为车辆类,摩托车类的基类为自行车类和机动车类,类之间均为公有继承,如图所示。
下载可执行文件链接motorcar.exe.
(1)根据上面各类间关系的描述,补全下面程序段中空缺的代码;
(2)实现程序中声明的成员函数,注意相应操作中的动作发生的条件不能满足时应给出提示。
(3)运行程序,享受开摩托的过程。(可以下载可执行文件motorcar.exe,先运行再编程。不必申请驾照,这个摩托车很安全。)
(4)在报告中,请用自己的话写清楚使用虚基类解决什么问题?

#include <iostream>
#include<conio.h>
#include <windows.h>
using namespace std;
enum vehicleStaus {rest, running};  //车辆状态:泊车、行进
class vehicle //车辆类
{
protected:
    int maxSpeed;		//最大车速
    int currentSpeed;	//当前速度
    int weight;			//车重
    vehicleStaus status; //rest-泊车状态;running-行进状态
public:
    vehicle(int maxS, int w); //构造函数,初始时,当前速度总为0且处在停车状态
    void start();  //由rest状态到running, 初速为1
    void stop(); //由running状态到rest, 当前速度小于5时,才允许停车
    void speed_up();  //加速,调用1次,速度加1
    void slow_down(); //减速,调用1次,速度减1,速度为0时,停车
};

class bicycle :_____(1)_________//(1)自行车类的虚基类为车辆类
{
protected:
    double height; //车高
public:
    bicycle(int maxS=10, int w=50, int h=0.7);   //定义构造函数
};

class motorcar : ______(2)__________//(2)机动车类的虚基类也为车辆类
{
protected:
    int seatNum; //座位数
    int passengerNum; //乘客人数
public:
    motorcar(int maxS=150, int w=1500, int s=5, int p=1);   //定义构造函数
    void addPassenger(int p=1);   //增加搭载的乘客,超员要拒载,有人下车时,p为负数。当然车上乘客至少有1个(司机)。只有车停稳后才能上下客。
};

class motorcycle: ______(3)_________ //(3)摩托车类的基类为自行车类和机动车类
{
public:
    motorcycle(int maxS=90, int w=100, int s=3, int p=1, int h=0.7);//定义构造函数
    void show(); //显示摩托车的运行状态
};

int main( )
{
    motorcycle m;
    bool end=false;
    while (!end)
    {
        cout<<"请操作:1-启动  2-加速  3-减速  4-有人上车  5-有人下车  6-停车 0-结束"<<endl;
        char keydown= _getch(); //_getch()返回键盘上读取的字符
        switch(keydown)
        {
        case '1':
            cout<<"选中的操作是1-启动\t";
            m.start();
            break;
        case '2':
            cout<<"选中的操作是2-加速\t";
            m.speed_up();
            break;
        case '3':
            cout<<"选中的操作是3-减速\t";
            m.slow_down();
            break;
        case '4':
            cout<<"选中的操作是4-有人上车\t";
            m.addPassenger();
            break;
        case '5':
            cout<<"选中的操作是5-有人下车\t";
            m.addPassenger(-1);
            break;
        case '6':
            cout<<"选中的操作是6-停车\t";
            m.stop();
            break;
        case '0':
            end=true;
            break;
        }
        m.show();
        cout<<endl;
        Sleep(200);  //要包含头文件<windows.h>
    }
    return 0;
}

参考运行结果如下:

请操作:1-启动  2-加速  3-减速  4-有人上车  5-有人下车  6-停车 0-结束
选中的操作是1-启动      状态:行进;    车速:1 / 90    当前乘员:1 / 3

请操作:1-启动  2-加速  3-减速  4-有人上车  5-有人下车  6-停车 0-结束
选中的操作是2-加速      状态:行进;    车速:2 / 90    当前乘员:1 / 3

请操作:1-启动  2-加速  3-减速  4-有人上车  5-有人下车  6-停车 0-结束
选中的操作是2-加速      状态:行进;    车速:3 / 90    当前乘员:1 / 3

请操作:1-启动  2-加速  3-减速  4-有人上车  5-有人下车  6-停车 0-结束
选中的操作是4-有人上车  车辆正在行驶,停车后再上下车!
状态:行进;    车速:3 / 90    当前乘员:1 / 3

请操作:1-启动  2-加速  3-减速  4-有人上车  5-有人下车  6-停车 0-结束
选中的操作是5-有人下车  车辆正在行驶,停车后再上下车!
状态:行进;    车速:3 / 90    当前乘员:1 / 3

请操作:1-启动  2-加速  3-减速  4-有人上车  5-有人下车  6-停车 0-结束
选中的操作是6-停车      状态:泊车;    车速:0 / 90    当前乘员:1 / 3

请操作:1-启动  2-加速  3-减速  4-有人上车  5-有人下车  6-停车 0-结束
选中的操作是4-有人上车  状态:泊车;    车速:0 / 90    当前乘员:2 / 3

请操作:1-启动  2-加速  3-减速  4-有人上车  5-有人下车  6-停车 0-结束
选中的操作是1-启动      状态:行进;    车速:1 / 90    当前乘员:2 / 3

请操作:1-启动  2-加速  3-减速  4-有人上车  5-有人下车  6-停车 0-结束
选中的操作是2-加速      状态:行进;    车速:2 / 90    当前乘员:2 / 3

请操作:1-启动  2-加速  3-减速  4-有人上车  5-有人下车  6-停车 0-结束
选中的操作是2-加速      状态:行进;    车速:3 / 90    当前乘员:2 / 3

请操作:1-启动  2-加速  3-减速  4-有人上车  5-有人下车  6-停车 0-结束
选中的操作是2-加速      状态:行进;    车速:4 / 90    当前乘员:2 / 3

请操作:1-启动  2-加速  3-减速  4-有人上车  5-有人下车  6-停车 0-结束
选中的操作是2-加速      状态:行进;    车速:5 / 90    当前乘员:2 / 3

请操作:1-启动  2-加速  3-减速  4-有人上车  5-有人下车  6-停车 0-结束
选中的操作是2-加速      状态:行进;    车速:6 / 90    当前乘员:2 / 3

请操作:1-启动  2-加速  3-减速  4-有人上车  5-有人下车  6-停车 0-结束
选中的操作是6-停车      车速太快!先减速再停车……
状态:行进;    车速:6 / 90    当前乘员:2 / 3

请操作:1-启动  2-加速  3-减速  4-有人上车  5-有人下车  6-停车 0-结束
选中的操作是3-减速      状态:行进;    车速:5 / 90    当前乘员:2 / 3

请操作:1-启动  2-加速  3-减速  4-有人上车  5-有人下车  6-停车 0-结束
选中的操作是3-减速      状态:行进;    车速:4 / 90    当前乘员:2 / 3

请操作:1-启动  2-加速  3-减速  4-有人上车  5-有人下车  6-停车 0-结束
选中的操作是6-停车      状态:泊车;    车速:0 / 90    当前乘员:2 / 3

请操作:1-启动  2-加速  3-减速  4-有人上车  5-有人下车  6-停车 0-结束
状态:泊车;    车速:0 / 90    当前乘员:2 / 3

Process returned 0 (0x0)   execution time : 73.297 s
Press any key to continue.

[参考解答]

【项目3】日期时间类
定义一个日期类Date,数据成员包括年、月、日,SetDate(int y,int m,int d)和PrintDate()函数分别用于设置日期和显示日期;再定义一个时间类Time,数据成员包括时、分、秒,SetTime(int h,int m,int s)和PrintTime()函数分别用于设置时间和显示时间,在此基础上再定义一个日期时间类TimeDate,充分利用已有的两个类中提供的方法,实现日期和时间的设置和显示。请实现类TimeDate,下面是用于测试的主函数及参考运行结果。

int main()
{
    TimeDate dt_a,dt_b(2010,4,16,9,30,0);
    cout<<"dt_a: ";
    dt_a.PrintDate_Time();
    cout<<endl;
    cout<<"dt_b: ";
    dt_b.PrintDate_Time();
    dt_a.SetTime(20,00,00);
    dt_a.SetDate(2008,8,7);
    cout<<endl;
    cout<<"dt_after uptate: ";
    dt_a.PrintDate_Time();
    return 0;
}

[参考解答]

【项目4 - 点、圆的关系】
(1)先建立一个Point(点)类,包含数据成员x,y(坐标点);
(2)以Point为基类,派生出一个Circle(圆)类,增加数据成员(半径),基类的成员表示圆心;
(3)编写上述两类中的构造、析构函数及必要运算符重载函数(本项目主要是输入输出);
(4)定义友元函数int locate,判断点p与圆的位置关系(返回值<0圆内,==0圆上,>0 圆外);

int main( )
{
	Circle c1(3,2,4),c2(4,5,5);      //c2应该大于c1
	Point p1(1,1),p2(3,-2),p3(7,3);  //分别位于c1内、上、外

	cout<<"圆c1: "<<c1;

	cout<<"点p1: "<<p1;
	cout<<"点p1在圆c1之"<<((locate(p1, c1)>0)?"外":((locate(p1, c1)<0)?"内":"上"))<<endl;

	cout<<"点p2: "<<p2;
	cout<<"点p2在圆c1之"<<((locate(p2, c1)>0)?"外":((locate(p2, c1)<0)?"内":"上"))<<endl;

	cout<<"点p3: "<<p3;
	cout<<"点p3在圆c1之"<<((locate(p3, c1)>0)?"外":((locate(p3, c1)<0)?"内":"上"))<<endl;
	return 0;
}

(5)在圆类上重载关系运算符(6种),使之能够按圆的面积比较两个圆的大小。自编main函数完成测试。
(6)与圆心相连的直线:给定一点p,其与圆心相连成的直线,会和圆有两个交点,如图。在上面定义的Point(点)类和Circle(圆)类基础上,设计一种方案,输出这两点的坐标。
提示:


[参考解答]

时间: 2024-09-03 16:05:57

《C++语言基础》实践项目——多重继承的相关文章

《大数据系统基础》课程实践项目中期答辩顺利举行,清华持续探索大数据人才教育创新之路

2017年11月15日,清华大学大数据能力提升项目之<大数据系统基础>课程实践项目中期答辩在清华大学六号教学楼顺利举行.160余名同学分为21组,向任课老师和企业导师汇报了各组实践项目的进展情况,任课老师和企业导师根据同学们的汇报表现逐一进行了点评和指导.据悉,本次答辩项目来自于国家发改委.百度.国美等政府机构和知名大数据企业等.项目需求和数据涉及多个行业领域,如"建设工程造价指数"."餐饮行业白皮书周报"."基于语义分析的泛娱乐改编研究&qu

《C++语言基础》网络课程主页

返回 贺利坚教学链接 本课程是在大学的实体课程基础上建设的一门网络课程,将我在教学中建设的资源,让更多的人能够用到. 课程链接是:点击打开链接 同步实体课在 点击打开链接,那里有92名同时学习的"同学",以及他们的博客链接. 坚持这门课程学习的学员,请在评论处留言,我将建立专门的链接,一起建设学习的氛围. 学员链接:(待加) 课程内容 一.从C到C++ 课时 视频 示例程序 自测 学习指导与实践 实践项目参考解答 1.1 由C语言到C++(暨本课介绍) 链接   1.2 C语言的基本成

C++语言基础-入门简介

C++是个强大的语言,可以用于做别的语言做不了的工作.但是,这种强大功能是有代价的.开始使用C++时,你可能会遇到内存溢出和访问失效等问题,使程序死机.这里用最简短的篇幅介绍C++语言基础.C++语言本身有专著介绍,这种书还特别厚,所以别指望我能用三言两语说清楚.读者学完本书并使用C++ Builder一般时间之后,最后对C++语言再作更深入的了解. C++可以最充分地利用面向对象编程(OOP)的优势.OOP不只是一个新名词,而有它的实际意义,可以生成可复用的对象.新术语 对象(object),

(cljs/run-at (-&gt;JSVM :browser) &quot;语言基础&quot;)

前言  两年多前知道cljs的存在时十分兴奋,但因为工作中根本用不上,国内也没有专门的职位于是搁置了对其的探索.而近一两年来又刮起了函数式编程的风潮,恰逢有幸主理新项目的前端架构,于是引入Ramda.js来疗藉心中压抑已久的渴望,谁知一发不可收拾,于是抛弃所有利益的考虑,遵循内心,好好追逐cljs一番:D  cljs就是ClojureScript的缩写,就是让Clojure代码transpile为JavaScript代码然后运行在浏览器或其他JSVM上的技术.由于宿主环境的不同,因此只能与宿主环

数据结构实践项目——排序

本文是[数据结构基础系列(9):排序]课程的实践项目. 本文针对: 1. 排序问题及导学 2. 插入排序之直接插入排序 3. 插入排序之希尔排序 4. 交换排序之冒泡排序 5. 交换排序之快速排序 6. 选择排序之直接选择排序 7. 选择排序之堆排序 8. 归并排序 9. 简单的计数排序 10. 基数排序 11. 各种排序的比较 纸上谈兵:"知原理"检验题目 1.给定序列{57, 40, 38, 11, 13, 34, 48, 75, 6, 19, 9, 7},采用下面的算法,分别描述

Swift语言指南(一)--语言基础之常量和变量

原文:Swift语言指南(一)--语言基础之常量和变量 Swift 是开发 iOS 及 OS X 应用的一门新编程语言,然而,它的开发体验与 C 或 Objective-C 有很多相似之处. Swift 提供了 C 与 Objective-C 中的所有基础类型,包括表示整数的 Int,表示浮点数的 Double 与 Float,表示布尔值的 Bool,以及表示纯文本数据的 String. Swift 还为两个基本集合类型 Array 与 Dictionary 提供了强大的支持,详情可参考 (集合

数据结构实践项目——图的基本运算及遍历操作

本文是针对[数据结构基础系列(7):图]中第1-9课时的实践项目. 0701 图结构导学 0702 图的定义 0703 图的基本术语 0704 图的邻接矩阵存储结构及算法 0705 图的邻接表存储结构及算法 0706 图的遍历 0707 非连通图的遍历 0708 DFS的应用 0709 BFS的应用 [项目1 - 图基本算法库] 定义图的邻接矩阵和邻接表存储结构,实现其基本运算,并完成测试. 要求: 1.头文件graph.h中定义相关的数据结构并声明用于完成基本运算的函数.对应基本运算的函数包括

数据结构实践项目——查找(一)

本文是[数据结构基础系列(8):查找]课程的第一组实践项目. 本文针对: 0801 查找问题导学 0802 线性表的顺序查找 0803 线性表的折半查找 0804 索引存储结构 0805 分块查找 0806 二叉排序树 0807 二叉排序树(续) 0808 平衡二叉树 纸上谈兵:"知原理"检验题目 [参考(部分)] [参考(1)] 1.对于A[0..10]有序表{12,18,24,35,47,50,62,83,90,115,134} (1)用二分查找法查找 90时,需进行多少次查找可确

Java语言基础细节归纳

俗话说的好,"万丈高楼平地起".由此观之,只有打好扎实地根基,才能筑造出稳健地高楼.对于我们学习和实践技术,也是同一个理. 本文有序地归纳了java语言基础细节,一是作为学习上的总结,二是避免触犯同样地错误,三是希望与同道之人交流.探讨和完善. 1.一个类定义前可以放置3类语句,分别为package.import和class语句,并且在一个Java源文件中有且只有一个被声明为public的类. 2.Java语言中规定,标识符不能使用规定的关键字和保留字,并且必须以一个字母.美元符号或下