【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;
		}
};
相关推荐
Molesidy1 小时前
【VSCode】【Clangd】Win下的基于LLVM/Clangd+Clangd插件+MINGW+CMake的VSCode配置C/C++开发环境的详细教程
c++·ide·vscode·clangd·llvm
报错小能手2 小时前
刷题日常 5 二叉树最大深度
算法
ᐇ9592 小时前
Java LinkedList集合全面解析:双向链表的艺术与实战
java·开发语言·链表
码银2 小时前
【数据结构】顺序表
java·开发语言·数据结构
Greedy Alg2 小时前
LeetCode 84. 柱状图中最大的矩形(困难)
算法
Mr_WangAndy2 小时前
C++_chapter13_C++并发与多线程_多线程概念,死锁,unique_lock(),lock_guard()使用
c++·lock·死锁·并发与多线程·unlock·lock_guard·unique_lock
im_AMBER2 小时前
Leetcode 52
笔记·学习·算法·leetcode
小欣加油2 小时前
leetcode 946 验证栈序列
c++·算法·leetcode·职场和发展
神仙别闹2 小时前
基于QT(C++) 实现哈夫曼压缩(多线程)
java·c++·qt