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;
    }
}
相关推荐
TracyCoder1234 分钟前
LeetCode Hot100(50/100)——153. 寻找旋转排序数组中的最小值
算法·leetcode·职场和发展
诸葛务农4 分钟前
点云配准在人形机器人中的应用:ICP算法(2)
人工智能·算法·机器学习·机器人
独自破碎E4 分钟前
BISHI43 讨厌鬼进货
android·java·开发语言
MX_93599 分钟前
Spring xml 方式整合第三方框架总结加案例
xml·java·spring
摘星编程10 分钟前
**解锁Agent智能体新纪元:自主协作、任务分解与人类意图对齐的终极指南**
算法
mmz120710 分钟前
逆序对问题(c++)
c++·算法
化学在逃硬闯CS11 分钟前
Leetcode110.平衡二叉树
数据结构·c++·算法·leetcode
谢铭轩13 分钟前
题解:P8035 [COCI 2015/2016 #7] Otpor
c++·算法
没有bug.的程序员13 分钟前
服务网格(Istio)与传统微服务深度对垒:流量治理内核、代码侵入性博弈与运维收益实战指南
java·运维·微服务·istio·流量治理内核·代码侵入性
该叫啥15 分钟前
Spring Bean 生命周期
java·spring·servlet