飞行的猪哼哼

  博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理

Problem Description

各位面向对象的小伙伴们,在学习了面向对象的核心概念——类的封装、继承、多态之后,答答租车系统开始营运了。
请你充分利用面向对象思想,为公司解决智能租车问题,根据客户选定的车型和租车天数,来计算租车费用,最大载客人数,最大载载重量。
公司现有三种车型(客车、皮卡车、货车),每种车都有名称和租金的属性;其中:客车只能载人,货车只能载货,皮卡车是客货两用车,即可以载人,也可以载货。
下面是答答租车公司的可用车型、容量及价目表:
序号 名称 载客量 载货量 租金
(人) (吨) (元/天)
1 A 5 800
2 B 5 400
3 C 5 800
4 D 51 1300
5 E 55 1500
6 F 5 0.45 500
7 G 5 2.0 450
8 H 3 200
9 I 25 1500
10 J 35 2000

要求:根据客户输入的所租车型的序号及天数,计算所能乘载的总人数、货物总数量及租车费用总金额。
Input

首行是一个整数:代表要不要租车 1——要租车(程序继续),0——不租车(程序结束);
第二行是一个整数,代表要租车的数量N;
接下来是N行数据,每行2个整数m和n,其中:m表示要租车的编号,n表示租用该车型的天数。
Output

若成功租车,则输出一行数据,数据间有一个空格,含义为:
载客总人数 载货总重量(保留2位小数) 租车金额(整数)
若不租车,则输出:
0 0.00 0(含义同上)
Sample Input

1
2
1 1
2 2
Sample Output

15 0.00 1600

import java.util.Scanner;

public class Main 
{
	public static void main(String[] args) 
	{
		Scanner reader=new Scanner(System.in);
		int T=reader.nextInt();
		if(T==0)
		{
			System.out.println("0 0.00 0");
		}
		else
		{
			int n=reader.nextInt();
			int sum1=0;
			double sum2=0;
			int sum3=0;
			for(int i=1;i<=n;i++)
			{
				int m1=reader.nextInt();
				int m2=reader.nextInt();
				if(m1==1||m1==3)
				{
					sum1=sum1+5*m2;
					sum3=sum3+800*m2;
				}
				if(m1==2)
				{
					sum1=sum1+5*m2;
					sum3=sum3+400*m2;
				}
				if(m1==4)
				{
					sum1=sum1+51*m2;
					sum3=sum3+1300*m2;
				}
				if(m1==5)
				{
					sum1=sum1+55*m2;
					sum3=sum3+1500*m2;
				}
				if(m1==6)
				{
					sum1=sum1+5*m2;
					sum2=sum2+0.45*m2;
					sum3=sum3+500*m2;
				}
				if(m1==7)
				{
					sum1=sum1+5*m2;
					sum2=sum2+2.0*m2;
					sum3=sum3+450*m2;
				}
				if(m1==8)
				{
					sum2=sum2+3*m2;
					sum3=sum3+200*m2;
				}
				if(m1==9)
				{
					sum2=sum2+25*m2;
					sum3=sum3+1500*m2;
				}
				if(m1==10)
				{
					sum2=sum2+35*m2;
					sum3=sum3+2000*m2;
				}
			}
			System.out.printf("%d %.2f %d\n",sum1,sum2,sum3);
		}
		reader.close();
	}
}

posted on 2018-10-30 21:00  飞行的猪哼哼  阅读(47)  评论(0)    收藏  举报