第十周项目5——摩托车继承自行车和机动车
来源:互联网 发布:exp数据库表结构导出 编辑:程序博客网 时间:2024/04/27 21:48
问题及代码:
/*copyright(c)2016.烟台大学计算机学院 * All rights reserved, * 文件名称:text.Cpp * 作者:李一波 * 完成日期:2016年5月14日 * 版本号:vc++6.0 * * 问题描述: * 输入描述: * 程序输出:在下面一段类的定义中,自行车类的虚基类为车辆类,机动车类的虚基类也为车辆类,摩托车类的基类为自行车类和机动车类,类之间均为公有继承,如图所示。 这里写图片描述 下载可执行文件链接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时,停车};vehicle::vehicle(int maxS, int w):maxSpeed(maxS), currentSpeed(0),weight(w), status(rest) {}void vehicle::start(){ if (status==rest) { status=running; currentSpeed=1; cout<<"状态:"<<"进行;"<<endl; } else cout<<"车辆已经行驶!"<<endl;}void vehicle::stop(){ if(status==running) if(currentSpeed>=5) cout<<"车速太快!先减速再停车……"<<endl; else cout<<"状态:"<<"泊车;"<<endl; else cout<<"车辆未启动"<<endl;}void vehicle::speed_up(){ if (status==running) if(currentSpeed<maxSpeed) currentSpeed++; else cout<<"请不要超速行驶……"<<endl; else cout<<"车辆未启动!"<<endl;}void vehicle::slow_down(){ if (status==running) { if(currentSpeed>0) currentSpeed--; } else cout<<"车辆未启动!"<<endl; if(currentSpeed==0) status=rest;}class bicycle:virtual public vehicle//(1)自行车类的虚基类为车辆类{protected: double height; //车高public: bicycle(int maxS=10, int w=50, int h=0.7); //定义构造函数};bicycle::bicycle(int maxS, int w, int h):vehicle(maxS,w),height(h){}class motorcar : virtual public vehicle//(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个(司机)。只有车停稳后才能上下客。};motorcar::motorcar(int maxS, int w, int s, int p):vehicle(maxS,w),seatNum(s),passengerNum(p){}void motorcar::addPassenger(int p){ if(status==running) cout<<"车辆正在行驶,停车后再下车!"<<endl; else { passengerNum+=p; if(passengerNum>seatNum) { passengerNum=seatNum; cout<<"涉嫌超员,已清理后达到满员!"<<endl; } else if(passengerNum<1) { passengerNum=1; cout<<"请司机不要离开岗位!"<<endl; } }}class motorcycle: public bicycle,public motorcar//(3)摩托车类的基类为自行车类和机动车类{public: motorcycle(int maxS=90, int w=100, int s=3, int p=1, int h=0.7);//定义构造函数 void show(); //显示摩托车的运行状态};motorcycle::motorcycle(int maxS, int w, int s, int p, int h):vehicle(maxS, w),bicycle(h),motorcar( s, p) {}void motorcycle::show(){ cout<<"状态:"; if(status==rest) cout<<"泊车;\t"; else cout<<"行进;\t"; cout<<"车速:"<<currentSpeed<<" / "<< maxSpeed <<"\t当前乘员:"<<passengerNum<<" / "<< seatNum << endl;}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;}
运行结果:
0 0
- 第十周项目5——摩托车继承自行车和机动车
- 第十一周实践项目5————摩托车继承自行车和机动车
- 第十.十一周项目5———摩托车继承自行车和机动车
- 第十一周项目5——摩托车继承自行车和机动车
- 第十二周项目3—摩托车继承自行车和机动车
- 第十、十一周项目5—摩托车继承自行车和机动车
- 第十周项目 2 摩托车继承自行车和机动车
- 第十周项目44-摩托车继承自行车和机动车
- 第十周项目六 摩托车继承自行车和机动车
- 第十周项目五 摩托车继承自行车和机动车
- 第十一周项目5-摩托车继承自行车和机动车
- 第十一周【项目5 - 摩托车继承自行车和机动车】
- 第十.十一周项目5摩托车继承自行车和机动车
- 第十一周项目5-摩托车继承自行车和机动车
- 第十周第十一周上机实践项目-项目5-摩托车继承自行车和机动车
- 项目5-摩托车继承自行车和机动车
- 第11周项目5—摩托车继承自行车和机动车
- 11周 5 项目 - 摩托车继承自行车和机动车
- 使用.NET Framework提供的InstallUtil.exe安装Windows服务安装时遇到的2种常见错误
- Android并发编程之图文解析volatile关键字
- Lucene 初探
- 1093. Count PAT's (25)【计数】——PAT (Advanced Level) Practise
- 说反话
- 第十周项目5——摩托车继承自行车和机动车
- spring源码解读
- QT-如何添加资源文件
- 字符串的反转
- Git与Repo入门
- Android并发编程之白话文详解Future,FutureTask和Callable
- 8086汇编语言课程设计一
- 【caffe配置】在vs2013用已经训练好的Alexnet网络提取fc6特征
- 1094. The Largest Generation (25)【二叉树】——PAT (Advanced Level) Practise