第十二周上机任务3
来源:互联网 发布:如何查看路由器端口号 编辑:程序博客网 时间:2024/04/30 00:15
/* (程序头部注释开始)* 程序的版权和版本声明部分* Copyright (c) 2011, 烟台大学计算机学院学生 * All rights reserved.* 文件名称:renwu.cpp * 作 者:宋本一 * 完成日期:2012 年 5 月 6 日* 版 本 号:12.3 * 对任务及求解方法的描述部分* 输入描述:略 * 问题描述:略 * 程序输出:略* 程序头部的注释结束*/#include <iostream> #include<conio.h> #include <windows.h> #include<iomanip> 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时,停车 int get_maxSpeed(){return maxSpeed;} int get_currentSpeed(){return currentSpeed;} int get_weight(){return weight;} int get_status(){return status;} }; vehicle::vehicle(int maxS, int w) //构造函数,初始时,当前速度总为0且处在停车状态 { maxSpeed=maxS; currentSpeed=0; weight=w; status=rest; } void vehicle::start() //由rest状态到running, 初速为1 { currentSpeed=1; status= running; } void vehicle::stop() //由running状态到rest, 当前速度小于5时,才允许停车 { if(currentSpeed<5) status=rest; else cout<<"当前速度大于5,不允许停车!"; } void vehicle::speed_up() //加速,调用1次,速度加1 { if(currentSpeed<maxSpeed) currentSpeed+=1; else cout<<"当前车速已是最大值,不允许加速!"; } void vehicle::slow_down() //减速,调用1次,速度减1,速度为0时,停车 { if(currentSpeed!=0) currentSpeed-=1; else status=rest; } class bicycle :virtual public vehicle //自行车类的虚基类为车辆类 { protected: double height; //车高 public: bicycle(int maxS=10, int w=50, double h=0.7); //定义构造函数 double get_height(){return height;} }; bicycle::bicycle(int maxS, int w, double h):vehicle(maxS,w) //定义构造函数 { height=h; } class motorcar :virtual public vehicle //机动车类的虚基类也为车辆类 { 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个(司机)。上下车时要保证安全…… int get_seatNum(){return seatNum;} int get_passengerNum(){return passengerNum;} }; motorcar::motorcar(int maxS, int w, int s, int p):vehicle(maxS,w) //定义构造函数 { seatNum=s; passengerNum=p; } void motorcar::addPassenger(int p) //搭载乘客,超员要拒载,有人下车时,p为负数。当然车上乘客至少有1个(司机)。上下车时要保证安全…… { if((p+passengerNum)>seatNum) cout<<"即将超载,请您等下一班车..."; passengerNum+=p; } class motorcycle: public bicycle,public motorcar //摩托车类的基类为自行车类和机动车类 { 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() //显示摩托车的运行状态 { cout<<"状态:"<<((status== rest)?"泊车":"行进")<<" "<<"车速:"<<currentSpeed<<'/'<<maxSpeed<<" "<<"当前成员"<<passengerNum<<'/'<<seatNum; } int main( ){motorcycle m;bool end=false;while (!end){cout<<"请操作:1-启动 2-加速 3-减速 4-有人上车 5-有人下车 6-停车 0-结束"<<endl;char keydown= _getch(); //_getch()返回键盘上读取的字符,应包含头文件<conio.h>switch(keydown){case '1': cout<<"操作(启动)\t"; m.start(); break;case '2': cout<<"操作(加速)\t"; m.speed_up(); break;case '3': cout<<"操作(减速)\t"; m.slow_down(); break;case '4': cout<<"操作(有人上车)\t"; m.addPassenger(); break;case '5': cout<<"操作(有人下车)\t"; m.addPassenger(-1); break;case '6': cout<<"操作(停车)\t"; m.stop(); break;case '0': end=true; break;}m.show();cout<<endl;Sleep(200); //要包含头文件<windows.h>}system("PAUSE"); return 0; }
运行结果:
请操作:1-启动 2-加速 3-减速 4-有人上车 5-有人下车 6-停车 0-结束
操作(启动) 状态:行进 车速:1/90 当前成员1/3
请操作:1-启动 2-加速 3-减速 4-有人上车 5-有人下车 6-停车 0-结束
操作(加速) 状态:行进 车速:2/90 当前成员1/3
请操作:1-启动 2-加速 3-减速 4-有人上车 5-有人下车 6-停车 0-结束
操作(减速) 状态:行进 车速:1/90 当前成员1/3
请操作:1-启动 2-加速 3-减速 4-有人上车 5-有人下车 6-停车 0-结束
操作(有人上车) 状态:行进 车速:1/90 当前成员2/3
请操作:1-启动 2-加速 3-减速 4-有人上车 5-有人下车 6-停车 0-结束
操作(有人下车) 状态:行进 车速:1/90 当前成员1/3
请操作:1-启动 2-加速 3-减速 4-有人上车 5-有人下车 6-停车 0-结束
操作(停车) 状态:泊车 车速:1/90 当前成员1/3
请操作:1-启动 2-加速 3-减速 4-有人上车 5-有人下车 6-停车 0-结束
状态:泊车 车速:1/90 当前成员1/3
请按任意键继续. . .
- 第十二周上机任务3
- 第十二周上机任务1
- 第十二周上机任务2
- 第十二周上机任务4
- 第十二周上机任务1
- 第十二周上机任务2
- 第十二周上机任务1
- 第十二周上机任务2
- 第十二周上机任务1
- 第十二周上机任务2
- 第十二周上机任务项目-3四数的最大公约数
- C++ 第十二周上机任务-输出“#”
- java上机 第十二周 任务一
- 第十二周上机任务==素数
- 第十二周上机任务项目-4输出10000以内回文素数任务3
- 第十二周任务3
- 第十二周任务3
- 第十二周任务3
- 2010-08-22_ximo_也来谈谈VMP2.05的脱壳
- 保持简单----纪念丹尼斯•里奇(Dennis Ritchie)
- 单片机抗干扰技术
- 一种常见的Java编程错误:没有同时定义equals()和hashCode()方法
- Hadoop Map/Reduce 新API中自己的FileInputFormat写法
- 第十二周上机任务3
- 2010.09.28_ximo_纠正下VMP脱壳中的修复DLL的错误
- Poj 1383 Labyrinth( 搜索获得全局最短路径 )
- 初篇---我的第一篇博客
- Android Browser的配置管理
- 利用抽象、多态实现无反射的绿色环保ORM框架
- MySQL新建用户,授权,删除用户,修改密码操作(win)
- Career Cup 2-3
- 梦入IBM之java基础第二天