【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;
		}
};
相关推荐
董董灿是个攻城狮12 小时前
AI视觉连载8:传统 CV 之边缘检测
算法
blasit18 小时前
笔记:Qt C++建立子线程做一个socket TCP常连接通信
c++·qt·tcp/ip
AI软著研究员19 小时前
程序员必看:软著不是“面子工程”,是代码的“法律保险”
算法
FunnySaltyFish19 小时前
什么?Compose 把 GapBuffer 换成了 LinkBuffer?
算法·kotlin·android jetpack
颜酱20 小时前
理解二叉树最近公共祖先(LCA):从基础到变种解析
javascript·后端·算法
地平线开发者1 天前
SparseDrive 模型导出与性能优化实战
算法·自动驾驶
董董灿是个攻城狮2 天前
大模型连载2:初步认识 tokenizer 的过程
算法
地平线开发者2 天前
地平线 VP 接口工程实践(一):hbVPRoiResize 接口功能、使用约束与典型问题总结
算法·自动驾驶
罗西的思考2 天前
AI Agent框架探秘:拆解 OpenHands(10)--- Runtime
人工智能·算法·机器学习
HXhlx2 天前
CART决策树基本原理
算法·机器学习