2015级C++第10、11周实践项目 继承和派生

简介: 【项目1 - 点-圆-圆柱类族的设计】参考解答 按以下的提示,由基类的设计和测试开始,逐渐地完成各个类的设计,求出圆格柱体的表面积、体积并输出并且完成要求的计算任务: (1)先建立一个Point(点)类,包含数据成员x,y(坐标点),实现需要的成员函数,并设计main函数完成测试; (2)以Point为基类,派生出一个Circle(圆)类,增加数

【项目1 - 点-圆-圆柱类族的设计】参考解答
按以下的提示,由基类的设计和测试开始,逐渐地完成各个类的设计,求出圆格柱体的表面积、体积并输出并且完成要求的计算任务:
(1)先建立一个Point(点)类,包含数据成员x,y(坐标点),实现需要的成员函数,并设计main函数完成测试;
(2)以Point为基类,派生出一个Circle(圆)类,增加数据成员r(半径),以及求面积的成员函数area,实现其他需要的成员函数,设计main函数完成测试;
(3)再以Circle类为直接基类,派生出一个Cylinder(圆柱体)类,再增加数据成员h(高),,以及求圆柱表面积的成员函数area和求圆柱体积的成员函数volume,实现需要的成员函数,并设计main函数完成测试。
(提示:此任务可以分为三个子任务分成若干步骤进行。先声明基类,再声明派生类,逐级进行,分步调试。——这种方法适用于做任何的项目)

【项目2 - 存储班长信息的学生类】参考解答

class Stu   //声明基类
{
public:
    Stu(int n, string nam );  //基类构造函数
    void display( );          //成员函数,输出基类数据成员
protected:        //(*)访问权限为保护型的数据成员
    int num;      //学生学号
    string name;  //学生姓名
};
class StuDetail: public Stu              //声明派生类StuDetail
{
public:
    //学生nam,学号n,a岁,家住ad,他的班长是nam1,学号n1
    StuDetail(int n, string nam,int a, string ad,int n1, string nam1); //派生类构造函数
    void show( ); //成员函数,输出学生的信息
    void show_monitor( );    //成员函数,输出班长信息
private:
    Stu monitor;   //学生所在班的班长,班长是学生,是Stu类的成员
    int age;       //学生年龄
    string addr;   //学生的住址
};
int main( )
{
    //学生王力,10010号,19岁,家住上海的北京路,他的班长是李孙,学号10001
    StuDetail s(10010,"Wang-li",19,"115 Beijing Road,Shanghai",10001,"Li-sun");
    s.show( );                       //输出学生信息
    s.show_monitor();                //输出班长信息
    return 0;
}

(1)上面是声明好的类及测试函数,请完成类中成员函数的定义,使运行结果如图所示。

(2)将Stu类的数据成员的访问权限改为private,你的程序是否能完成要求的功能?如果不行,请修改程序。请不要修改给出的代码,只能修改自己写的代码。

【项目3 - 警察和厨师】参考解答
(1)根据下面的类图,定义各个类:
这里写图片描述

要求:
各个成员函数,只要输出相关的信息即可,暂不深究其业务功能
请为各个类增加构造函数
在实现中,可以增加需要的其他函数
自行编制main函数,完成初步的测试

(2)下面的类图,为Polic类和Cook类增加了对象成员,请扩充代码,完成上述各项要求
这里写图片描述

【项目4- 教师兼干部类】参考解答
  分别定义Teacher(教师)类和Cadre(干部)类,采用多重继承方式由这两个类派生出新类Teacher_Cadre(教师兼干部)。
  要求:
  (1)在两个基类中都包含姓名、年龄、性别、地址、电话等数据成员。
  (2)在Teacher类中还包含数据成员title(职称),在Cadre类中还包含数据成员post(职务),在Teacher_Cadre类中还包含数据成员wages(工资)。
  (3)对两个基类中的姓名、年龄、性别、地址、电话等数据成员用相同的名字,在引用这些数据成员时,指定作用域。
  (4)在类体中声明成员函数,在类外定义成员函数。
  (5)在派生类Teacher_Cadre的成员函数show中调用Teacher类中的display函数,输出姓名、年龄、性别、职称、地址、电话,然后再用cout语句输出职务与工资。
  
【项目5 - 摩托车继承自行车和机动车】参考解答
  在下面一段类的定义中,自行车类的虚基类为车辆类,机动车类的虚基类也为车辆类,摩托车类的基类为自行车类和机动车类,类之间均为公有继承,如图所示。
  这里写图片描述
  下载可执行文件链接motorcar.exe.
(1)根据上面各类间关系的描述,补全下面程序段中空缺的代码;
(2)实现程序中声明的成员函数,注意相应操作中的动作发生的条件不能满足时应给出提示。
(3)运行程序,享受开摩托的过程。(可以在博客中下载可执行文件,先开摩托,再编程。不必申请驾照,这个摩托车很安全。)
(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.
目录
相关文章
|
1月前
|
存储 C语言 C++
【C++数据结构——栈与队列】顺序栈的基本运算(头歌实践教学平台习题)【合集】
本关任务:编写一个程序实现顺序栈的基本运算。开始你的任务吧,祝你成功!​ 相关知识 初始化栈 销毁栈 判断栈是否为空 进栈 出栈 取栈顶元素 1.初始化栈 概念:初始化栈是为栈的使用做准备,包括分配内存空间(如果是动态分配)和设置栈的初始状态。栈有顺序栈和链式栈两种常见形式。对于顺序栈,通常需要定义一个数组来存储栈元素,并设置一个变量来记录栈顶位置;对于链式栈,需要定义节点结构,包含数据域和指针域,同时初始化栈顶指针。 示例(顺序栈): 以下是一个简单的顺序栈初始化示例,假设用C语言实现,栈中存储
141 77
|
1月前
|
存储 C++
【C++数据结构——树】哈夫曼树(头歌实践教学平台习题) 【合集】
【数据结构——树】哈夫曼树(头歌实践教学平台习题)【合集】目录 任务描述 相关知识 测试说明 我的通关代码: 测试结果:任务描述 本关任务:编写一个程序构建哈夫曼树和生成哈夫曼编码。 相关知识 为了完成本关任务,你需要掌握: 1.如何构建哈夫曼树, 2.如何生成哈夫曼编码。 测试说明 平台会对你编写的代码进行测试: 测试输入: 1192677541518462450242195190181174157138124123 (用户分别输入所列单词的频度) 预
58 14
【C++数据结构——树】哈夫曼树(头歌实践教学平台习题) 【合集】
|
1月前
|
存储 C++ 索引
【C++数据结构——栈与队列】环形队列的基本运算(头歌实践教学平台习题)【合集】
【数据结构——栈与队列】环形队列的基本运算(头歌实践教学平台习题)【合集】初始化队列、销毁队列、判断队列是否为空、进队列、出队列等。本关任务:编写一个程序实现环形队列的基本运算。(6)出队列序列:yzopq2*(5)依次进队列元素:opq2*(6)出队列序列:bcdef。(2)依次进队列元素:abc。(5)依次进队列元素:def。(2)依次进队列元素:xyz。开始你的任务吧,祝你成功!(4)出队一个元素a。(4)出队一个元素x。
42 13
【C++数据结构——栈与队列】环形队列的基本运算(头歌实践教学平台习题)【合集】
|
1月前
|
C++ 芯片
【C++面向对象——类与对象】Computer类(头歌实践教学平台习题)【合集】
声明一个简单的Computer类,含有数据成员芯片(cpu)、内存(ram)、光驱(cdrom)等等,以及两个公有成员函数run、stop。只能在类的内部访问。这是一种数据隐藏的机制,用于保护类的数据不被外部随意修改。根据提示,在右侧编辑器补充代码,平台会对你编写的代码进行测试。成员可以在派生类(继承该类的子类)中访问。成员,在类的外部不能直接访问。可以在类的外部直接访问。为了完成本关任务,你需要掌握。
68 19
|
1月前
|
存储 编译器 数据安全/隐私保护
【C++面向对象——类与对象】CPU类(头歌实践教学平台习题)【合集】
声明一个CPU类,包含等级(rank)、频率(frequency)、电压(voltage)等属性,以及两个公有成员函数run、stop。根据提示,在右侧编辑器补充代码,平台会对你编写的代码进行测试。​ 相关知识 类的声明和使用。 类的声明和对象的声明。 构造函数和析构函数的执行。 一、类的声明和使用 1.类的声明基础 在C++中,类是创建对象的蓝图。类的声明定义了类的成员,包括数据成员(变量)和成员函数(方法)。一个简单的类声明示例如下: classMyClass{ public: int
47 13
|
1月前
|
Java C++
【C++数据结构——树】二叉树的基本运算(头歌实践教学平台习题)【合集】
本关任务:编写一个程序实现二叉树的基本运算。​ 相关知识 创建二叉树 销毁二叉树 查找结点 求二叉树的高度 输出二叉树 //二叉树节点结构体定义 structTreeNode{ intval; TreeNode*left; TreeNode*right; TreeNode(intx):val(x),left(NULL),right(NULL){} }; 创建二叉树 //创建二叉树函数(简单示例,手动构建) TreeNode*create
46 12
|
1月前
|
C++
【C++数据结构——树】二叉树的性质(头歌实践教学平台习题)【合集】
本文档介绍了如何根据二叉树的括号表示串创建二叉树,并计算其结点个数、叶子结点个数、某结点的层次和二叉树的宽度。主要内容包括: 1. **定义二叉树节点结构体**:定义了包含节点值、左子节点指针和右子节点指针的结构体。 2. **实现构建二叉树的函数**:通过解析括号表示串,递归地构建二叉树的各个节点及其子树。 3. **使用示例**:展示了如何调用 `buildTree` 函数构建二叉树并进行简单验证。 4. **计算二叉树属性**: - 计算二叉树节点个数。 - 计算二叉树叶子节点个数。 - 计算某节点的层次。 - 计算二叉树的宽度。 最后,提供了测试说明及通关代
42 10
|
1月前
|
算法 C++
【C++数据结构——图】最小生成树(头歌实践教学平台习题) 【合集】
【数据结构——图】最小生成树(头歌实践教学平台习题)目录 任务描述 相关知识 测试说明 我的通关代码: 测试结果:【合集】任务描述 本关任务:编写一个程序求图的最小生成树。相关知识 为了完成本关任务,你需要掌握:1.建立邻接矩阵,2.Prim算法。建立邻接矩阵 上述带权无向图对应的二维数组,根据它建立邻接矩阵,如图1建立下列邻接矩阵。注意:INF表示无穷大,表示整数:32767 intA[MAXV][MAXV];Prim算法 普里姆(Prim)算法是一种构造性算法,从候选边中挑
42 10
|
1月前
|
存储 算法 C++
【C++数据结构——图】图的邻接矩阵和邻接表的存储(头歌实践教学平台习题)【合集】
本任务要求编写程序实现图的邻接矩阵和邻接表的存储。需掌握带权有向图、图的邻接矩阵及邻接表的概念。邻接矩阵用于表示顶点间的连接关系,邻接表则通过链表结构存储图信息。测试输入为图的顶点数、边数及邻接矩阵,预期输出为Prim算法求解结果。通关代码提供了完整的C++实现,包括输入、构建和打印邻接矩阵与邻接表的功能。
46 10
|
1月前
|
C++
【C++数据结构——栈和队列】括号配对(头歌实践教学平台习题)【合集】
【数据结构——栈和队列】括号配对(头歌实践教学平台习题)【合集】(1)遇到左括号:进栈Push()(2)遇到右括号:若栈顶元素为左括号,则出栈Pop();否则返回false。(3)当遍历表达式结束,且栈为空时,则返回true,否则返回false。本关任务:编写一个程序利用栈判断左、右圆括号是否配对。为了完成本关任务,你需要掌握:栈对括号的处理。(1)遇到左括号:进栈Push()开始你的任务吧,祝你成功!测试输入:(()))
37 7