【C++】6-11 停车场收费问题 分数 20

6-11 停车场收费问题

分数 20

全屏浏览

切换布局

作者 徐婉珍

单位 广东东软学院

在停车场收费系统中,收费者会根据车型的不同按不同的单价和计费方式收取不同的停车费,其中:

复制代码
  轿车Car:每小时8元,超过30分钟按一小时计算,未超过30分钟不收费 
复制代码
  客车Bus:每小时10元,30分钟以内按半小时计费,未达1小时但超过30分钟按1小时计算
复制代码
      货车Truck:每小时15元,未达1小时的按1小时计算
复制代码
      其他未知类型:按默认方法计算,见裁判程序。

请补充必要的类和函数定义,使停车场类Parker可收取停入的n辆车的费用。

裁判测试程序样例:

cpp 复制代码
#include <iostream>
#include <string>
using namespace std;
const float Car_Price= 8;
const float Bus_Price= 10;
const float Truck_Price=15;
class Vehicle{
    protected:
        float price;
        int minute;
    public:
       virtual float computeFee(){return 20.0f*minute/60;};
       virtual string getType(){return "unknow"; };
       float getPrice();
       void setPrice(float _price);
       int getMinute();
       void setMinute(int _minute);
       Vehicle(float _price,int _minute); 
       Vehicle(){
       };
};
/* 你的代码将被嵌入这里 */
int main(){
    int n,minute; //停车辆次,时长 
    char type;
    Vehicle *vp;
    Parker p;
    cin>>n;
    
    for(int i=1;i<=n;i++){
        cin>>type>>minute;
        switch(type){
            case 'c':vp=new Car(minute);break;
            case 't':vp=new Truck(minute);break;
            case 'b':vp=new Bus(minute);break;
            default: vp=new Vehicle();vp->setMinute(minute);
        }
        cout<<"type:"<<vp->getType() <<" minute:"<<vp->getMinute()<<" fee:"<<vp->computeFee()<<endl;
        p.park(vp);
        delete vp;
    }
    cout<<"sum:"<<p.getSum()<<endl;
    return 0;
}

输入样例:

输入的第一行为进入停车场的车辆总数n.

接下来有n行输入,每行为一辆车的类型及停车时长,时长单位为分钟,类型'c'代表Car,类型'b'代表Bus,类型't'代表Truck,其他字符则为未知类型。

复制代码
3
c 40
t 5
b 40

输出样例:

输出为n+1行,前n行输出每辆车的类型,停车时长,收取的费用,最后一行输出目前停车场得到的停车费总额。

复制代码
type:car minute:40 fee:8
type:truck minute:5 fee:15
type:bus minute:40 fee:10
sum=33

代码长度限制

16 KB

时间限制

400 ms

内存限制

64 MB

cpp 复制代码
int Vehicle::getMinute(){
	return minute;
}
void Vehicle::setMinute(int m){
	minute = m;
}
class Parker{
	private:
		double sum;
	public:
		
		Parker(){
			sum = 0;
		}
		void park(Vehicle *a){
			sum+=a->computeFee();
		}
		double getSum(){
			return sum;
		}
};
class Car : public Vehicle{
	public:
		Car(int m){
			price = 8;
			minute = m;
		}
		string getType(){
			return"car";
		}
		float computeFee(){
			if(minute%60>=30)return (minute/60+1)*price;
			else return minute/60*price;
		}
};
class Truck:public Vehicle{
	public:
		Truck(int m){
			price=15;
			minute = m;
		}
			string getType(){
			return"truck";
		}
		float computeFee(){
			if(minute%60==0)return minute/60*price;
			else return (minute/60+1)*price;
		}	
};
class Bus:public Vehicle{
	public:
		Bus(int m){
			price=10;
			minute = m;
		}
			string getType(){
			return"bus";
		}
		float computeFee(){
			if(minute%60>30)return (minute/60+1)*price;
			else if(minute%60==0)return minute/60*price;
			else return (minute/60+0.5)*price;
		}
};
相关推荐
灰子学技术4 小时前
go response.Body.close()导致连接异常处理
开发语言·后端·golang
那个村的李富贵5 小时前
CANN加速下的AIGC“即时翻译”:AI语音克隆与实时变声实战
人工智能·算法·aigc·cann
二十雨辰5 小时前
[python]-AI大模型
开发语言·人工智能·python
power 雀儿5 小时前
Scaled Dot-Product Attention 分数计算 C++
算法
Yvonne爱编码5 小时前
JAVA数据结构 DAY6-栈和队列
java·开发语言·数据结构·python
Re.不晚5 小时前
JAVA进阶之路——无奖问答挑战1
java·开发语言
你这个代码我看不懂5 小时前
@ConditionalOnProperty不直接使用松绑定规则
java·开发语言
pas1365 小时前
41-parse的实现原理&有限状态机
开发语言·前端·javascript
琹箐5 小时前
最大堆和最小堆 实现思路
java·开发语言·算法
renhongxia16 小时前
如何基于知识图谱进行故障原因、事故原因推理,需要用到哪些算法
人工智能·深度学习·算法·机器学习·自然语言处理·transformer·知识图谱