【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;
		}
};
相关推荐
以卿a12 分钟前
C++ 模板初阶
开发语言·c++
s:10316 分钟前
【框架】参考 Spring Security 安全框架设计出,轻量化高可扩展的身份认证与授权架构
java·开发语言
道不尽世间的沧桑1 小时前
第17篇:网络请求与Axios集成
开发语言·前端·javascript
久绊A1 小时前
Python 基本语法的详细解释
开发语言·windows·python
软件黑马王子5 小时前
C#初级教程(4)——流程控制:从基础到实践
开发语言·c#
闲猫5 小时前
go orm GORM
开发语言·后端·golang
计算机小白一个5 小时前
蓝桥杯 Java B 组之设计 LRU 缓存
java·算法·蓝桥杯
万事可爱^6 小时前
HDBSCAN:密度自适应的层次聚类算法解析与实践
算法·机器学习·数据挖掘·聚类·hdbscan
黑不溜秋的6 小时前
C++ 设计模式 - 策略模式
c++·设计模式·策略模式
李白同学6 小时前
【C语言】结构体内存对齐问题
c语言·开发语言