【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;
		}
};
相关推荐
lxyzcm10 分钟前
C++23新特性解析:[[assume]]属性
java·c++·spring boot·c++23
蜀黍@猿28 分钟前
C/C++基础错题归纳
c++
古希腊掌管学习的神30 分钟前
[搜广推]王树森推荐系统笔记——曝光过滤 & Bloom Filter
算法·推荐算法
qystca31 分钟前
洛谷 P1706 全排列问题 C语言
算法
古希腊掌管学习的神36 分钟前
[LeetCode-Python版]相向双指针——611. 有效三角形的个数
开发语言·python·leetcode
赵钰老师37 分钟前
【R语言遥感技术】“R+遥感”的水环境综合评价方法
开发语言·数据分析·r语言
浊酒南街37 分钟前
决策树(理论知识1)
算法·决策树·机器学习
雨中rain43 分钟前
Linux -- 从抢票逻辑理解线程互斥
linux·运维·c++
就爱学编程1 小时前
重生之我在异世界学编程之C语言小项目:通讯录
c语言·开发语言·数据结构·算法
学术头条1 小时前
清华、智谱团队:探索 RLHF 的 scaling laws
人工智能·深度学习·算法·机器学习·语言模型·计算语言学