pta-6-8 快递计价器

现需要编写一个简易快递计价程序。具体来说:

1、抽象 快递类Express,其包含一个属性int weight表示快递重量(单位为kg),一个方法getWeight()用于返回快递重量和一个抽象方法 getTotal()用于计算快递运费。

2、两个类继承Express,分别是:

(a)顺路快递SLExpress:计价规则为首重(1kg)12元,每增加1kg费用加2元。

(b)地地快递DDExpress:计价规则为首重(1kg)5元,每增加1kg费用加1元。

3、菜菜驿站类CaicaiStation,提供静态方法 int calculate(Express[] ex) 用于计算所有快递的费用。

输入样例:

复制代码
6
SL 2
DD 2
SL 1
SL 1
SL 1
DD 3

输入解释:

第1行n表示需要计算的快递件数

第2至n+1表示每个快递信息,即选哪家快递公司 以及快递的重量(单位kg)

输出样例:

复制代码
63

输出解释:

所有快递总运费。

裁判测试程序样例:

复制代码
import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        Express[] ex = new Express[n];
        for (int i = 0; i < ex.length; i++) {
            if (sc.next().equals("SL"))
                ex[i] = new SLExpress(sc.nextInt());
            else
                ex[i] = new DDExpress(sc.nextInt());
        }

        System.out.println(CaicaiStation.calculate(ex));
        sc.close();
    }
}
/* 请在这里填写答案 */

正确答案:

复制代码
// 抽象快递类
abstract class Express {
    protected int weight; // 快递重量

    public Express(int weight) {
        this.weight = weight;
    }

    public int getWeight() {
        return weight;
    }

    // 抽象方法,用于计算快递费用
    public abstract int getTotal();
}

// 顺路快递类
class SLExpress extends Express {
    public SLExpress(int weight) {
        super(weight);
    }

    @Override
    public int getTotal() {
        // 首重1kg 12元,每增加1kg加2元
        return 12 + Math.max(0, weight - 1) * 2;
    }
}

// 地地快递类
class DDExpress extends Express {
    public DDExpress(int weight) {
        super(weight);
    }

    @Override
    public int getTotal() {
        // 首重1kg 5元,每增加1kg加1元
        return 5 + Math.max(0, weight - 1);
    }
}

// 菜菜驿站类
class CaicaiStation {
    // 静态方法,用于计算所有快递的费用
    public static int calculate(Express[] ex) {
        int total = 0;
        for (Express e : ex) {
            total += e.getTotal();
        }
        return total;
    }
}
相关推荐
重生之后端学习几秒前
21. 合并两个有序链表
java·算法·leetcode·链表·职场和发展
源代码•宸1 分钟前
Leetcode—1266. 访问所有点的最小时间【简单】
开发语言·后端·算法·leetcode·职场和发展·golang
遇见~未来5 分钟前
JavaScript数组全解析:从本质到高级技巧
开发语言·前端·javascript
南屿欣风5 分钟前
Sentinel 熔断规则 - 异常比例(order & product 示例)笔记
java·开发语言
u01040583612 分钟前
使用Java实现高性能的异步编程:CompletableFuture与Reactive Streams
java·开发语言
朔北之忘 Clancy19 分钟前
2020 年 6 月青少年软编等考 C 语言二级真题解析
c语言·开发语言·c++·学习·青少年编程·题解·尺取法
YuTaoShao23 分钟前
【LeetCode 每日一题】712. 两个字符串的最小ASCII删除和——(解法一)记忆化搜索
算法·leetcode·职场和发展
消失的旧时光-194325 分钟前
C++ 中的 auto 与 nullptr:不是语法糖,而是类型系统升级
开发语言·c++
专注VB编程开发20年26 分钟前
c#Type数组转成字符串的名称
java·开发语言
中年程序员一枚30 分钟前
多数据源的springboot进行动态连接方案
java·spring boot·后端