十二周项目2
2015-05-27 09:19
148 查看
#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; } else cout<<"车辆已启动。"<<endl; } void vehicle::stop() { if (status==running) if(currentSpeed<5) { status=rest; currentSpeed=0; } 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); }; 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) { passengerNum+=p; if(passengerNum>seatNum) cout<<"已超载。"<<endl; else cout<<"欢迎乘坐。"<<endl; } } class motorcycle:virtual public motorcar,virtual public bicycle//(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(maxS, w, h),motorcar(maxS, w, s, p) {} void motorcycle::show() { if(status==running) cout<<"行进中"<<endl; else cout<<"停车。"<<" "; cout<<"车速:"<<currentSpeed<<" / "<< maxSpeed <<" 当前乘员:"<<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; }
相关文章推荐
- 第十二周项目2—操作用邻接表存储的图
- 十二周 项目五 迷宫问题之图深度优先遍历解法
- 十二周项目三(4)——出口fibnacci第一序列20的数量
- 十二周项目二 不太符合要求的投机取巧的程序
- 十二周项目一
- 十二周项目一 图基本算法库
- 十二周 项目4- 利用遍历思想求解图问题
- 第十二周实践项目1————实现复数类中的运算符重载之成员函数
- 第十二周项目1-Prim算法的验证
- 第十二周项目三用递归方法求解(3)
- 第十二周项目3--图遍历算法实现--实现广度优先遍历——BFS
- 十二周 项目三 图遍历算法实现(BFS)
- 十二周项目一(4)
- 第十二周项目一阅读程序(3)
- 十二周 项目1-图基本算法库
- 第十二周项目3—利用遍历思想求解图问题
- 十二周 项目四 利用遍历思想求解图问题(3)
- 十二周 项目四 利用遍历思想求解图问题(5)
- 第十二周项目1:阅读程序并写出结果(3)
- 地十二周项目四(3) 选择法排序