答答租车系统(面向对象综合练习)

本文介绍了一个基于面向对象设计的智能租车系统,通过不同车型的数据,实现了根据用户需求计算租车费用、最大载客人数及最大载货量的功能。

Time Limit: 1000 ms Memory Limit: 65536 KiB
Submit Statistic
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
Hint

Source
zhouxq

import java.util.*;

class myclass {
    int ren;
    double huo;
    int tian;

    myclass(int a, double b, int c) {
        ren = a;
        huo = b;
        tian = c;
    }
}

class Main {
    public static void main(String[] args) {

        Scanner ss = new Scanner(System.in);
        int flag;
        int n;
        myclass my[] = new myclass[15];
        int a[] = { 5, 5, 5, 51, 55, 5, 5, 0, 0, 0 };
        double b[] = { 0.0, 0.0, 0.0, 0.0, 0.0, 0.45, 2.0, 3.0, 25.0, 35.0 };
        int c[] = { 800, 400, 800, 1300, 1500, 500, 450, 200, 1500, 2000 };
        for (int i = 0; i < 10; i++) {
            my[i] = new myclass(a[i], b[i], c[i]);
        }
        while (ss.hasNextInt()) {
            flag = ss.nextInt();
            if (flag == 0) {
                System.out.println("0 0.00 0");
                break;
            } else {
                n = ss.nextInt();
                int suma = 0;
                double sumb = 0.0;
                int sumc = 0;
                while (n > 0) {
                    int num, day;
                    num = ss.nextInt();
                    day = ss.nextInt();
                    suma += my[num - 1].ren * day;
                    sumb += my[num - 1].huo * day;
                    sumc += my[num - 1].tian * day;
                    n--;
                }
                System.out.printf("%d %.2f %d\n", suma, sumb, sumc);
            }

        }
        ss.close();
    }
}
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值