PTA-6-42 设计门票(抽象类)

题目:

某学校举办一次活动,需要凭票参加,每张票都有票号和售价。

门票分为3类:当天票,预订票和学生预订票。

当天票价格50。

预订票,提前时间>10天的,售价30;提前10天以内的,售价40;

学生预订票,提前时间>10天的,售价15;提前10天以内的,售价20。

(1)编写抽象类Ticket类,包含以下成员

①属性:

number:私有,int型,表示票号;

②方法:

  1. Ticket(int number), 构造方法,初始化票号;
  2. int getPrice(), 返回票价,抽象方法;
  3. String toString(),返回一个字符串,格式为"Number:票号,Price:票价"。

(2)编写Ticket类的子类WalkupTicket,表示当天票,包含以下成员

①方法:

1)WalkupTicket(int number), 构造方法,初始化票号;

2)int getPrice(), 返回票价50。

(3)编写Ticket类的子类AdvanceTicket,表示预订票,包含以下成员

①属性:

  1. leadTime:私有,int型,表示提前预订的天数;
    ②方法:
  2. AdvanceTicket(int number,int leadTime), 构造方法,初始化票号和提前天数;
  3. int getPrice(), 如果提前天数>10天,票价30,否则,票价40。

(4)编写AdvanceTicket类的子类StudentAdvanceTicket,表示学生预订票,包含以下成员

①属性:

  1. height:私有,int型,表示购票学生的身高(单位厘米);

    ②方法:

    1)StudentAdvanceTicket(int number,int leadTime,int height), 构造方法,初始化票号、提前天数和身高;

    2)int getPrice(),

    如果学生身高>120:提前天数>10天,票价20,否则,票价30。

    如果学生身高<=120,票价是身高120以上学生的对折。

题目给出裁判测试程序样例如下:

java 复制代码
public class Main{
    public static void main(String args[]) {
        Scanner in = new Scanner(System.in);
        Ticket a = new WalkupTicket(in.nextInt());
        System.out.println(a.toString());
        Ticket b = new AdvanceTicket(in.nextInt(), in.nextInt());
        System.out.println(b.toString());
        Ticket c = new StudentAdvanceTicket(in.nextInt(), in.nextInt(), in.nextInt());
        System.out.println(c.toString());
    }
}

通过阅读题目,我们可以从中提炼出以下几点实现要求:

1、编写抽象类Ticket类,来初始化票号,返回票价以及返回一个字符串

2、编写Ticket类的子类WalkupTicket用于表示当天票

3、编写Ticket类的子类AdvanceTicket用于表示预定票

4、编写AdvanceTicket类的子类StudentAdvanceTicket用于表示学生预订票

代码实现如下:

java 复制代码
abstract class Ticket {
    private int number;
    public Ticket(int number) {
        this.number = number;
    }

    abstract int getPrice();
    
    public String toString() {
        return "Number:"+number+",Price:"+getPrice();
    }
    public int getNumber() {
        return number;
    }
    public void setNumber(int number) {
        this.number = number;
    }
}
class WalkupTicket extends Ticket {

    public WalkupTicket(int number) {
        super(number);
    }

    @Override
    int getPrice() {
        return 50;
    }
}
class AdvanceTicket extends Ticket {
    private int leadTime;
    public AdvanceTicket(int number,int leadTime) {
        super(number);
        this.leadTime = leadTime;
    }

    @Override
    int getPrice() {
        if(leadTime>10)
            return 30;
        else 
            return 40;
    }
}
class StudentAdvanceTicket extends AdvanceTicket {
    private int height;
    int lead;
    public StudentAdvanceTicket(int number,int leadTime,int height) {
        super(number,leadTime);
        this.lead=leadTime;
        this.height = height;
    }

    @Override
    int getPrice() {
        if(height>120) {
            if(lead>10)
                return 20;
            else 
                return 30;
        }
        else {
            if(lead>10)
                return 10;
            else
                return 15;
        }
            
    }
}

注:编写 toString方法返回字符串时需要注意输出格式不要错误。


以上就是 **PTA-6-42 设计门票(抽象类)**的全部内容了,希望能对你有所帮助!

相关推荐
ulias2121 分钟前
leetcode热题 - 5
数据结构·算法·leetcode
Resistance丶未来2 分钟前
Coding-Interview-University 学习路径实战评测
人工智能·gpt·学习·github·claude·gemini·kimi
Lyyaoo.5 分钟前
【JAVA Spring面经】Spring 事务失效情况
java·数据库·spring
ErizJ9 分钟前
Docker | 学习笔记
笔记·学习·docker
Funny_AI_LAB12 分钟前
Naval最新播客谈“氛围编码”:Vibe Coding 开启“一人独角兽”时代
人工智能·算法·语言模型·agi
如何原谅奋力过但无声12 分钟前
【灵神高频面试题合集04-05】二分查找
数据结构·python·算法·leetcode
初心未改HD13 分钟前
Go 泛型完全指南:从入门到实战
开发语言·golang
salipopl14 分钟前
Spring Boot 整合 Druid 并开启监控
java·spring boot·后端
我不是懒洋洋16 分钟前
【数据结构】排序算法(直接插入排序、希尔排序、选择排序、堆排序、冒泡排序、快速排序、归并排序、计数排序)
c语言·数据结构·c++·经验分享·算法·排序算法
MediaTea16 分钟前
ML:逻辑回归的基本原理与实现
人工智能·算法·机器学习·数据挖掘·逻辑回归