首页 > 其他分享 >BLOG-2

BLOG-2

时间:2023-06-30 17:01:50浏览次数:40  
标签:输出 int double BLOG table 空格 public

BLOG-2

前言

这次blog是关于pta题目集4-6和期中考试的总结,菜单计价系统还是挺难的,而期中考试就较为简单,题量也不大,但就是很耗时间。

7-1 菜单计价程序-4

分数 100

全屏浏览题目

切换布局

作者 蔡轲

单位 南昌航空大学

本体大部分内容与菜单计价程序-3相同,增加的部分用加粗文字进行了标注。

设计点菜计价程序,根据输入的信息,计算并输出总价格。

输入内容按先后顺序包括两部分:菜单、订单,最后以"end"结束。

菜单由一条或多条菜品记录组成,每条记录一行

每条菜品记录包含:菜名、基础价格 两个信息。

订单分:桌号标识、点菜记录和删除信息、代点菜信息。每一类信息都可包含一条或多条记录,每条记录一行或多行。

桌号标识独占一行,包含两个信息:桌号、时间。

桌号以下的所有记录都是本桌的记录,直至下一个桌号标识。

点菜记录包含:序号、菜名、份额、份数。份额可选项包括:1、2、3,分别代表小、中、大份。

不同份额菜价的计算方法:小份菜的价格=菜品的基础价格。中份菜的价格=菜品的基础价格1.5。小份菜的价格=菜品的基础价格2。如果计算出现小数,按四舍五入的规则进行处理。

删除记录格式:序号 delete

标识删除对应序号的那条点菜记录。

如果序号不对,输出"delete error"

代点菜信息包含:桌号 序号 菜品名称 份额 分数

代点菜是当前桌为另外一桌点菜,信息中的桌号是另一桌的桌号,带点菜的价格计算在当前这一桌。

程序最后按输入的桌号从小到大的顺序依次输出每一桌的总价(注意:由于有代点菜的功能,总价不一定等于当前桌上的菜的价格之和)。

每桌的总价等于那一桌所有菜的价格之和乘以折扣。如存在小数,按四舍五入规则计算,保留整数。

折扣的计算方法(注:以下时间段均按闭区间计算):

周一至周五营业时间与折扣:晚上(17:00-20:30)8折,周一至周五中午(10:30--14:30)6折,其余时间不营业。

周末全价,营业时间:9:30-21:30

如果下单时间不在营业范围内,输出"table " + t.tableNum + " out of opening hours"

参考以下类的模板进行设计(本内容与计价程序之前相同,其他类根据需要自行定义):

菜品类:对应菜谱上一道菜的信息。

Dish {

String name;//菜品名称

int unit_price; //单价

int getPrice(int portion)//计算菜品价格的方法,输入参数是点菜的份额(输入数据只能是1/2/3,代表小/中/大份) }

菜谱类:对应菜谱,包含饭店提供的所有菜的信息。

Menu {

Dish[] dishs ;//菜品数组,保存所有菜品信息

Dish searthDish(String dishName)//根据菜名在菜谱中查找菜品信息,返回Dish对象。

Dish addDish(String dishName,int unit_price)//添加一道菜品信息

}

点菜记录类:保存订单上的一道菜品记录

Record {

int orderNum;//序号

Dish d;//菜品\\

int portion;//份额(1/2/3代表小/中/大份)

int getPrice()//计价,计算本条记录的价格

}

订单类:保存用户点的所有菜的信息。

Order {

Record[] records;//保存订单上每一道的记录

int getTotalPrice()//计算订单的总价

Record addARecord(int orderNum,String dishName,int portion,int num)//添加一条菜品信息到订单中。

delARecordByOrderNum(int orderNum)//根据序号删除一条记录

findRecordByNum(int orderNum)//根据序号查找一条记录

}

本次课题比菜单计价系列-3增加的异常情况:

1、菜谱信息与订单信息混合,应忽略夹在订单信息中的菜谱信息。输出:"invalid dish"

2、桌号所带时间格式合法(格式见输入格式部分说明,其中年必须是4位数字,月、日、时、分、秒可以是1位或2位数),数据非法,比如:2023/15/16 ,输出桌号+" date error"

3、同一桌菜名、份额相同的点菜记录要合并成一条进行计算,否则可能会出现四舍五入的误差。

4、重复删除,重复的删除记录输出"deduplication :"+序号。

5、代点菜时,桌号不存在,输出"Table number :"+被点菜桌号+" does not exist";本次作业不考虑两桌记录时间不匹配的情况。

6、菜谱信息中出现重复的菜品名,以最后一条记录为准。

7、如果有重复的桌号信息,如果两条信息的时间不在同一时间段,(时段的认定:周一到周五的中午或晚上是同一时段,或者周末时间间隔1小时(不含一小时整,精确到秒)以内算统一时段),此时输出结果按不同的记录分别计价。

8、重复的桌号信息如果两条信息的时间在同一时间段,此时输出结果时合并点菜记录统一计价。前提:两个的桌号信息的时间都在有效时间段以内。计算每一桌总价要先合并符合本条件的饭桌的点菜记录,统一计价输出。

9、份额超出范围(1、2、3)输出:序号+" portion out of range "+份额,份额不能超过1位,否则为非法格式,参照第13条输出。

10、份数超出范围,每桌不超过15份,超出范围输出:序号+" num out of range "+份数。份数必须为数值,最高位不能为0,否则按非法格式参照第16条输出。

11、桌号超出范围[1,55]。输出:桌号 +" table num out of range",桌号必须为1位或多位数值,最高位不能为0,否则按非法格式参照第16条输出。

12、菜谱信息中菜价超出范围(区间(0,300)),输出:菜品名+" price out of range "+价格,菜价必须为数值,最高位不能为0,否则按非法格式参照第16条输出。

13、时间输入有效但超出范围[2022.1.1-2023.12.31],输出:"not a valid time period"

14、一条点菜记录中若格式正确,但数据出现问题,如:菜名不存在、份额超出范围、份数超出范围,按记录中从左到右的次序优先级由高到低,输出时只提示优先级最高的那个错误。

15、每桌的点菜记录的序号必须按从小到大的顺序排列(可以不连续,也可以不从1开始),未按序排列序号的输出:"record serial number sequence error"。当前记录忽略。(代点菜信息的序号除外)

16、所有记录其它非法格式输入,统一输出"wrong format"

17、如果记录以“table”开头,对应记录的格式或者数据不符合桌号的要求,那一桌下面定义的所有信息无论正确或错误均忽略,不做处理。如果记录不是以“table”开头,比如“tab le 55 2023/3/2 12/00/00”,该条记录认为是错误记录,后面所有的信息并入上一桌一起计算。

本次作业比菜单计价系列-3增加的功能:

菜单输入时增加特色菜,特色菜的输入格式:菜品名+英文空格+基础价格+"T"

例如:麻婆豆腐 9 T

菜价的计算方法:

周一至周五 7折, 周末全价。

注意:不同的四舍五入顺序可能会造成误差,请按以下步骤累计一桌菜的菜价:

计算每条记录的菜价:将每份菜的单价按份额进行四舍五入运算后,乘以份数计算多份的价格,然后乘以折扣,再进行四舍五入,得到本条记录的最终支付价格。

最后将所有记录的菜价累加得到整桌菜的价格。

输入格式:

桌号标识格式:table + 序号 +英文空格+ 日期(格式:YYYY/MM/DD)+英文空格+ 时间(24小时制格式: HH/MM/SS)

菜品记录格式:

菜名+英文空格+基础价格

如果有多条相同的菜名的记录,菜品的基础价格以最后一条记录为准。

点菜记录格式:序号+英文空格+菜名+英文空格+份额+英文空格+份数注:份额可输入(1/2/3), 1代表小份,2代表中份,3代表大份。

删除记录格式:序号 +英文空格+delete

代点菜信息包含:桌号+英文空格+序号+英文空格+菜品名称+英文空格+份额+英文空格+分数

最后一条记录以“end”结束。

输出格式:

按输入顺序输出每一桌的订单记录处理信息,包括:

1、桌号,格式:table+英文空格+桌号+”:”+英文空格

2、按顺序输出当前这一桌每条订单记录的处理信息,

每条点菜记录输出:序号+英文空格+菜名+英文空格+价格。其中的价格等于对应记录的菜品*份数,序号是之前输入的订单记录的序号。如果订单中包含不能识别的菜名,则输出“** does not exist”,**是不能识别的菜名

如果删除记录的序号不存在,则输出“delete error”

最后按输入顺序一次输出每一桌所有菜品的总价(整数数值)格式:table+英文空格+桌号+“:”+英文空格+当前桌的原始总价+英文空格+当前桌的计算折扣后总价

输入样例:

在这里给出一组输入。例如:

麻婆豆腐 12

油淋生菜 9 T

table 31 2023/2/1 14/20/00

1 麻婆豆腐 1 16

2 油淋生菜 1 2

2 delete

2 delete

end

输出样例:

在这里给出相应的输出。例如:

table 31:

1 num out of range 16

2 油淋生菜 18

deduplication 2

table 31: 0 0

输入样例1:

份数超出范围+份额超出范围。例如:

麻婆豆腐 12

油淋生菜 9 T

table 31 2023/2/1 14/20/00

1 麻婆豆腐 1 16

2 油淋生菜 4 2

end

输出样例1:

份数超出范围+份额超出范围。例如:

table 31:

1 num out of range 16

2 portion out of range 4

table 31: 0 0

输入样例2:

桌号信息错误。例如:

麻婆豆腐 12

油淋生菜 9 T

table a 2023/3/15 12/00/00

1 麻婆豆腐 1 1

2 油淋生菜 2 1

end

输出样例2:

在这里给出相应的输出。例如:

wrong format

输入样例3:

混合错误:桌号信息格式错误+混合的菜谱信息(菜谱信息忽略)。例如:

麻婆豆腐 12

油淋生菜 9 T

table 55 2023/3/31 12/000/00

麻辣香锅 15

1 麻婆豆腐 1 1

2 油淋生菜 2 1

end

输出样例3:

在这里给出相应的输出。例如:

wrong format

输入样例4:

错误的菜谱记录。例如:

麻婆豆腐 12.0

油淋生菜 9 T

table 55 2023/3/31 12/00/00

麻辣香锅 15

1 麻婆豆腐 1 1

2 油淋生菜 2 1

end

输出样例4:

在这里给出相应的输出。例如:

wrong format

table 55:

invalid dish

麻婆豆腐 does not exist

2 油淋生菜 14

table 55: 14 10

输入样例5:

桌号格式错误(以“table”开头)+订单格式错误(忽略)。例如:

麻婆豆腐 12

油淋生菜 9 T

table a 2023/3/15 12/00/00

1 麻婆 豆腐 1 1

2 油淋生菜 2 1

end

输出样例5:

在这里给出相应的输出。例如:

wrong format

输入样例6:

桌号格式错误,不以“table”开头。例如:

麻婆豆腐 12

油淋生菜 9 T

table 1 2023/3/15 12/00/00

1 麻婆豆腐 1 1

2 油淋生菜 2 1

tab le 2 2023/3/15 12/00/00

1 麻婆豆腐 1 1

2 油淋生菜 2 1

end

输出样例6:

在这里给出相应的输出。例如:

table 1:

1 麻婆豆腐 12

2 油淋生菜 14

wrong format

record serial number sequence error

record serial number sequence error

table 1: 26 17

 

 

源码如下:

 

import java.util.*;

 

class Dish {

String name;

int unit_price;

 

public Dish(String name, int unit_price) {

    this.name = name;

    this.unit_price = unit_price;

}

 

public int getPrice(int portion) {

    double price = unit_price;

    if (portion == 2) {

        price *= 1.5;

    } else if (portion == 3) {

        price *= 2;

    }

    return (int) Math.round(price);

}

}

 

class Menu {

List<Dish> dishes;

 

public Menu() {

    dishes = new ArrayList<>();

}

 

public void addDish(String name, int unit_price) {

    dishes.add(new Dish(name, unit_price));

}

 

public Dish searchDish(String dishName) {

    for (Dish dish : dishes) {

        if (dish.name.equals(dishName)) {

            return dish;

        }

    }

    return null;

}

}

 

class Record {

int orderNum;

Dish dish;

int portion;

int num;

 

public Record(int orderNum, Dish dish, int portion, int num) {

    this.orderNum = orderNum;

    this.dish = dish;

    this.portion = portion;

    this.num = num;

}

 

public int getPrice() {

    return dish.getPrice(portion) * num;

}

}

 

class Order {

List<Record> records;

 

public Order() {

    records = new ArrayList<>();

}

 

public void addRecord(int orderNum, Dish dish, int portion, int num) {

    records.add(new Record(orderNum, dish, portion, num));

}

 

public void deleteRecord(int orderNum) {

    for (int i = 0; i < records.size(); i++) {

        if (records.get(i).orderNum == orderNum) {

            records.remove(i);

            return;

        }

    }

    System.out.println("delete error");

}

 

public int getTotalPrice() {

    int totalPrice = 0;

    for (Record record : records) {

        totalPrice += record.getPrice();

    }

    return totalPrice;

}

}

 

public class Main {

public static void main(String[] args) {

Scanner scanner = new Scanner(System.in);

Menu menu = new Menu();

Order currentOrder = null;

Map<Integer, Order> orders = new TreeMap<>();

 

    while (scanner.hasNextLine()) {

        String line = scanner.nextLine();

        if (line.equals("end")) {

            break;

        }

        if (line.startsWith("table")) {

            String[] tableInfo = line.split(" ");

            int tableNum = Integer.parseInt(tableInfo[1]);

            String date = tableInfo[2];

            String time = tableInfo[3];

            currentOrder = new Order();

            orders.put(tableNum, currentOrder);

        } else if (line.contains("delete")) {

            int orderNum = Integer.parseInt(line.split(" ")[0]);

            currentOrder.deleteRecord(orderNum);

        } else if (line.contains("T")) {

            String[] dishInfo = line.split(" ");

            String dishName = dishInfo[0];

            int unit_price = Integer.parseInt(dishInfo[1]);

            menu.addDish(dishName, unit_price);

        } else {

            String[] recordInfo = line.split(" ");

            int orderNum = Integer.parseInt(recordInfo[0]);

            String dishName = recordInfo[1];

            int portion = Integer.parseInt(recordInfo[2]);

            int num = Integer.parseInt(recordInfo[3]);

            Dish dish = menu.searchDish(dishName);

            if (dish == null) {

                System.out.println(dishName + " does not exist");

                continue;

            }

            currentOrder.addRecord(orderNum, dish, portion, num);

        }

    }

 

    for (Map.Entry<Integer, Order> entry : orders.entrySet()) {

        int tableNum = entry.getKey();

        Order order = entry.getValue();

        int totalPrice = order.getTotalPrice();

        int finalPrice = calculateFinalPrice(tableNum, totalPrice);

        System.out.println("table " + tableNum + ": " + totalPrice + " " + finalPrice);

    }

}

 

public static int calculateFinalPrice(int tableNum, int totalPrice) {

    int finalPrice;

if (isOpeningHours(tableNum)) {

finalPrice = (int) Math.round(totalPrice * getDiscountRate(tableNum));

} else {

finalPrice = totalPrice;

}

return finalPrice;

}

 

public static boolean isOpeningHours(int tableNum) {

    // 判断是否在营业时间内

    // 周一至周五晚上(17:00-20:30)8折,周一至周五中午(10:30-14:30)6折,周末全价

    // 根据桌号的时间信息判断是否在营业时间内

    return true; // 这里需要根据具体的判断条件进行实现

}

 

public static double getDiscountRate(int tableNum) {

    // 根据桌号的时间信息返回折扣率

    // 周一至周五晚上(17:00-20:30)8折,周一至周五中午(10:30-14:30)6折,周末全价

    return 1.0; // 这里需要根据具体的判断条件返回对应的折扣率

}

}

 

这次的题目有大量的异常输入,一开始没有思路解决,后面与同学讨论了很久,才解决,通过含参构造将输入的数据存入Record类或Menu类中或对Record类中的数据进行处理。

 

 

7-1 菜单计价程序-5

分数 100

全屏浏览题目

切换布局

作者 蔡轲

单位 南昌航空大学

本题在菜单计价程序-3的基础上增加了部分内容,增加的内容用加粗字体标识。

注意不是菜单计价程序-4,本题和菜单计价程序-4同属菜单计价程序-3的两个不同迭代分支



设计点菜计价程序,根据输入的信息,计算并输出总价格。

 

输入内容按先后顺序包括两部分:菜单、订单,最后以"end"结束。

 

菜单由一条或多条菜品记录组成,每条记录一行

 

每条菜品记录包含:菜名、基础价格  三个信息。

 

订单分:桌号标识、点菜记录和删除信息、代点菜信息。每一类信息都可包含一条或多条记录,每条记录一行或多行。

 

桌号标识独占一行,包含两个信息:桌号、时间。

 

桌号以下的所有记录都是本桌的记录,直至下一个桌号标识。

 

点菜记录包含:序号、菜名、份额、份数。份额可选项包括:1、2、3,分别代表小、中、大份。

 

不同份额菜价的计算方法:小份菜的价格=菜品的基础价格。中份菜的价格=菜品的基础价格1.5。小份菜的价格=菜品的基础价格2。如果计算出现小数,按四舍五入的规则进行处理。

 

删除记录格式:序号  delete

 

标识删除对应序号的那条点菜记录。

 

如果序号不对,输出"delete error"

 

代点菜信息包含:桌号 序号 菜品名称 口味度 份额 份数

 

代点菜是当前桌为另外一桌点菜,信息中的桌号是另一桌的桌号,带点菜的价格计算在当前这一桌。

 

程序最后按输入的先后顺序依次输出每一桌的总价(注意:由于有代点菜的功能,总价不一定等于当前桌上的菜的价格之和)。

 

每桌的总价等于那一桌所有菜的价格之和乘以折扣。如存在小数,按四舍五入规则计算,保留整数。

 

折扣的计算方法(注:以下时间段均按闭区间计算):

 

周一至周五营业时间与折扣:晚上(17:00-20:30)8折,周一至周五中午(10:30--14:30)6折,其余时间不营业。

 

周末全价,营业时间:9:30-21:30

 

如果下单时间不在营业范围内,输出"table " + t.tableNum + " out of opening hours"

 

参考以下类的模板进行设计:菜品类:对应菜谱上一道菜的信息。

 

Dish {    

 

   String name;//菜品名称    

 

   int unit_price;    //单价    

 

   int getPrice(int portion)//计算菜品价格的方法,输入参数是点菜的份额(输入数据只能是1/2/3,代表小/中/大份)    }

 

菜谱类:对应菜谱,包含饭店提供的所有菜的信息。

 

Menu {

 

   Dish[] dishs ;//菜品数组,保存所有菜品信息

 

   Dish searthDish(String dishName)//根据菜名在菜谱中查找菜品信息,返回Dish对象。

 

   Dish addDish(String dishName,int unit_price)//添加一道菜品信息

 

}

 

点菜记录类:保存订单上的一道菜品记录

 

Record {

 

   int orderNum;//序号\\

 

   Dish d;//菜品\\

 

   int portion;//份额(1/2/3代表小/中/大份)\\

 

   int getPrice()//计价,计算本条记录的价格\\

 

}

 

订单类:保存用户点的所有菜的信息。

 

Order {

 

   Record[] records;//保存订单上每一道的记录

 

   int getTotalPrice()//计算订单的总价

 

   Record addARecord(int orderNum,String dishName,int portion,int num)//添加一条菜品信息到订单中。

 

   delARecordByOrderNum(int orderNum)//根据序号删除一条记录

 

   findRecordByNum(int orderNum)//根据序号查找一条记录

 

}

 

### 输入格式:

 

桌号标识格式:table + 序号 +英文空格+ 日期(格式:YYYY/MM/DD)+英文空格+ 时间(24小时制格式: HH/MM/SS)

 

菜品记录格式:

 

菜名+英文空格+基础价格

 

如果有多条相同的菜名的记录,菜品的基础价格以最后一条记录为准。

 

点菜记录格式:序号+英文空格+菜名+英文空格+份额+英文空格+份数注:份额可输入(1/2/3), 1代表小份,2代表中份,3代表大份。

 

删除记录格式:序号 +英文空格+delete

 

代点菜信息包含:桌号+英文空格+序号+英文空格+菜品名称+英文空格+份额+英文空格+分数

 

最后一条记录以“end”结束。

 

### 输出格式:

 

按输入顺序输出每一桌的订单记录处理信息,包括:

 

1、桌号,格式:table+英文空格+桌号+”:”

 

2、按顺序输出当前这一桌每条订单记录的处理信息,

 

每条点菜记录输出:序号+英文空格+菜名+英文空格+价格。其中的价格等于对应记录的菜品\*份数,序号是之前输入的订单记录的序号。如果订单中包含不能识别的菜名,则输出“\*\* does not exist”,\*\*是不能识别的菜名

 

如果删除记录的序号不存在,则输出“delete error”

 

最后按输入顺序一次输出每一桌所有菜品的总价(整数数值)格式:table+英文空格+桌号+“:”+英文空格+当前桌的总价

 

以上为菜单计价系列-3的题目要求,加粗的部分是有调整的内容。本次课题相比菜单计价系列-3新增要求如下:

 

1、菜单输入时增加特色菜,特色菜的输入格式:菜品名+英文空格+口味类型+英文空格+基础价格+"T"

例如:麻婆豆腐川菜 9 T

菜价的计算方法:

周一至周五 7折,周末全价。

特色菜的口味类型:川菜、晋菜、浙菜

川菜增加辣度值:辣度0-5级;对应辣度水平为:不辣、微辣、稍辣、辣、很辣、爆辣;

晋菜增加酸度值,酸度0-4级;对应酸度水平为:不酸、微酸、稍酸、酸、很酸;

浙菜增加甜度值,甜度0-3级;对应酸度水平为:不甜、微甜、稍甜、甜;    

例如:麻婆豆腐 川菜 9 T

输入订单记录时如果是特色菜,添加口味度(辣//甜度)值,格式为:序号+英文空格+菜名+英文空格+口味度值+英文空格+份额+英文空格+份数

例如:1 麻婆豆腐 4 1 9

单条信息在处理时,如果口味度超过正常范围,输出"spicy/acidity/sweetness num out of range : "+口味度值,spicy/acidity/sweetness(辣度/酸度/甜度)根据菜品类型择一输出,例如:

acidity num out of range : 5

输出一桌的信息时,按辣、酸、甜度的顺序依次输出本桌菜各种口味的口味度水平,如果没有某个类型的菜,对应的口味(辣//甜)度不输出,只输出已点的菜的口味度。口味度水平由口味度平均值确定,口味度平均值只综合对应口味菜系的菜计算,不做所有菜的平均。比如,某桌菜点了3份川菜,辣度分别是135;还有4份晋菜,酸度分别是,1122,辣度平均值为3、酸度平均值四舍五入为2,甜度没有,不输出。

一桌信息的输出格式:table+英文空格+桌号+:+英文空格+当前桌的原始总价+英文空格+当前桌的计算折扣后总价+英文空格+"川菜"+数量+辣度+英文空格+"晋菜"+数量+酸度+英文空格+"浙菜"+数量+甜度。

如果整桌菜没有特色菜,则只输出table的基本信息,格式如下,注意最后加一个英文空格:

table+英文空格+桌号+:+英文空格+当前桌的原始总价+英文空格+当前桌的计算折扣后总价+英文空格

例如:table 1: 60 36 川菜 2 爆辣浙菜 1 微甜

计算口味度时要累计本桌各类菜系所有记录的口味度总和(每条记录的口味度乘以菜的份数),再除以对应菜系菜的总份数,最后四舍五入。

注:本题要考虑代点菜的情况,当前桌点的菜要加上被其他桌代点的菜综合计算口味度平均值。

 

 

2、考虑客户订多桌菜的情况,输入时桌号时,增加用户的信息:

格式:table+英文空格+桌号+英文空格+":"+英文空格+客户姓名+英文空格+手机号+日期(格式:YYYY/MM/DD+英文空格+ 时间(24小时制格式: HH/MM/SS

例如:table 1 : tom 13670008181 2023/5/1 21/30/00

约束条件:客户姓名不超过10个字符,手机号11位,前三位必须是180181189133135136其中之一。

输出结果时,先按要求输出每一桌的信息,最后按字母顺序依次输出每位客户需要支付的金额。不考虑各桌时间段的问题,同一个客户的所有table金额都要累加。

输出用户支付金额格式:

用户姓名+英文空格+手机号+英文空格+支付金额

 

 

注意:不同的四舍五入顺序可能会造成误差,请按以下步骤累计一桌菜的菜价:

 

计算每条记录的菜价:将每份菜的单价按份额进行四舍五入运算后,乘以份数计算多份的价格,然后乘以折扣,再进行四舍五入,得到本条记录的最终支付价格。

将所有记录的菜价累加得到整桌菜的价格。

输入格式:

桌号标识格式:table + 序号 +英文空格+ 日期(格式:YYYY/MM/DD)+英文空格+ 时间(24小时制格式: HH/MM/SS)

 

菜品记录格式:

 

菜名+口味类型+英文空格+基础价格

 

如果有多条相同的菜名的记录,菜品的基础价格以最后一条记录为准。

 

点菜记录格式:序号+英文空格+菜名+英文空格+//甜度值+英文空格+份额+英文空格+份数 注:份额可输入(1/2/3), 1代表小份,2代表中份,3代表大份。//甜度取值范围见题目中说明。

 

删除记录格式:序号 +英文空格+delete

 

代点菜信息包含:桌号+英文空格+序号+英文空格+菜品名称**+英文空格+辣/酸/甜度值+**英文空格+份额+英文空格+分数

 

最后一条记录以“end”结束。

输出格式:

按输入顺序输出每一桌的订单记录处理信息,包括:

 

1、桌号,格式:table+英文空格+桌号+“:”+英文空格

 

2、按顺序输出当前这一桌每条订单记录的处理信息,

 

每条点菜记录输出:序号+英文空格+菜名+英文空格+价格。其中的价格等于对应记录的菜品\*份数,序号是之前输入的订单记录的序号。如果订单中包含不能识别的菜名,则输出“\*\* does not exist”,\*\*是不能识别的菜名

 

如果删除记录的序号不存在,则输出“delete error”

 

之后按输入顺序一次输出每一桌所有菜品的价格(整数数值),

格式:table+英文空格+桌号+“:”+英文空格+当前桌的计算折扣后总价+英文空格+辣度平均值+英文空格+酸度平均值+英文空格+甜度平均值+英文空格

 

最后按拼音顺序输出每位客户(不考虑客户同名或拼音相同的情况)的支付金额,格式: 用户姓名+英文空格+手机号+英文空格+支付总金额,按输入顺序排列。

输入样例1:

桌号时间超出营业范围。例如:

麻婆豆腐 川菜 12 T

油淋生菜 9

麻辣鸡丝 10

table 1 : tom 13605054400 2023/5/1 21/30/00

1 麻婆豆腐 3 1 2

2 油淋生菜 2 1

3 麻婆豆腐 2 3 2

end

输出样例1:

在这里给出相应的输出。例如:

table 1 out of opening hours

输入样例2:

一种口味的菜品。例如:

麻婆豆腐 川菜 12 T

油淋生菜 9

麻辣鸡丝 10

table 1 : tom 13605054400 2023/5/1 20/30/00

1 麻婆豆腐 2 1 2

2 油淋生菜 2 1

3 麻婆豆腐 2 3 2

end

输出样例2:

在这里给出相应的输出。例如:

table 1:

1 麻婆豆腐 24

2 油淋生菜 14

3 麻婆豆腐 48

table 1: 86 62 川菜 4 稍辣

tom 13605054400 62

 

输入样例3:

辣度值超出范围。例如:

麻婆豆腐 川菜 12 T

油淋生菜 9

麻辣鸡丝 10

table 1 : tom 13605054400 2023/5/1 18/30/00

1 麻婆豆腐 6 1 2

2 油淋生菜 1 1

3 麻婆豆腐 5 3 2

end

输出样例3:

在这里给出相应的输出。例如:

table 1:

spicy num out of range :6

2 油淋生菜 9

3 麻婆豆腐 48

table 1: 57 41 川菜 2 爆辣

tom 13605054400 41

输入样例4:

同一用户对应多桌菜。例如:

麻婆豆腐 川菜 12 T

油淋生菜 9

麻辣鸡丝 10

table 1 : tom 13605054400 2023/5/1 18/30/00

1 麻婆豆腐 1 1 2

2 油淋生菜 1 1

3 麻婆豆腐 2 2 2

table 2 : tom 13605054400 2023/5/6 18/30/00

1 麻婆豆腐 2 1 2

2 麻辣鸡丝 2 2

3 麻婆豆腐 2 1 1

end

输出样例4:

在这里给出相应的输出。例如:

table 1:

1 麻婆豆腐 24

2 油淋生菜 9

3 麻婆豆腐 36

table 2:

1 麻婆豆腐 24

2 麻辣鸡丝 30

3 麻婆豆腐 12

table 1: 69 49 川菜 4 稍辣

table 2: 66 66 川菜 3 稍辣

tom 13605054400 115

输入样例5:

多用户多桌菜。例如:

东坡肉 浙菜 25 T

油淋生菜 9

蜜汁灌藕 浙菜 10 T

刀削面 晋菜 10 T

醋浇羊肉 晋菜 30 T

麻婆豆腐 川菜 12 T

麻辣鸡丝 川菜 15 T

table 1 : tom 13605054400 2023/5/6 12/30/00

1 醋浇羊肉 4 1 1

3 刀削面 1 1 3

2 东坡肉 3 2 1

4 麻辣鸡丝 2 1 1

table 2 : jerry 18100334566 2023/5/1 12/30/00

1 醋浇羊肉 1 1 2

3 麻婆豆腐 2 2 1

4 麻辣鸡丝 2 3 3

table 3 : jerry 18100334566 2023/5/1 12/30/00

1 醋浇羊肉 2 1 1

3 蜜汁灌藕 1 1 2

2 东坡肉 2 2 1

4 麻辣鸡丝 5 1 1

end

输出样例5:

在这里给出相应的输出。例如:

table 1:

1 醋浇羊肉 30

3 刀削面 30

2 东坡肉 38

4 麻辣鸡丝 15

table 2:

1 醋浇羊肉 60

3 麻婆豆腐 18

4 麻辣鸡丝 90

table 3:

1 醋浇羊肉 30

3 蜜汁灌藕 20

2 东坡肉 38

4 麻辣鸡丝 15

table 1: 113 113 川菜 1 稍辣 晋菜 4 稍酸 浙菜 1 甜

table 2: 168 118 川菜 4 稍辣 晋菜 2 微酸

table 3: 103 73 川菜 1 爆辣 晋菜 1 稍酸 浙菜 3 微甜

jerry 18100334566 191

tom 13605054400 113

输入样例6:

多用户多桌菜含代点菜。例如:

东坡肉 浙菜 25 T

油淋生菜 9

蜜汁灌藕 浙菜 10 T

刀削面 晋菜 10 T

醋浇羊肉 晋菜 30 T

麻婆豆腐 川菜 12 T

麻辣鸡丝 川菜 15 T

table 1 : tom 13605054400 2023/5/6 12/30/00

1 醋浇羊肉 4 1 1

3 刀削面 1 1 3

2 东坡肉 3 2 1

4 麻辣鸡丝 2 1 1

table 2 : jerry 18100334566 2023/5/1 12/30/00

1 1 醋浇羊肉 0 1 2

3 麻婆豆腐 2 2 1

4 麻辣鸡丝 2 3 3

table 3 : lucy 18957348763 2023/5/1 12/30/00

1 醋浇羊肉 2 1 1

3 蜜汁灌藕 1 1 2

2 东坡肉 2 2 1

4 麻辣鸡丝 5 1 1

end

输出样例6:

在这里给出相应的输出。例如:

table 1:

1 醋浇羊肉 30

3 刀削面 30

2 东坡肉 38

4 麻辣鸡丝 15

table 2:

1 table 2 pay for table 1 60

3 麻婆豆腐 18

4 麻辣鸡丝 90

table 3:

1 醋浇羊肉 30

3 蜜汁灌藕 20

2 东坡肉 38

4 麻辣鸡丝 15

table 1: 113 113 川菜 1 稍辣 晋菜 6 微酸 浙菜 1 甜

table 2: 168 118 川菜 4 稍辣

table 3: 103 73 川菜 1 爆辣 晋菜 1 稍酸 浙菜 3 微甜

jerry 18100334566 118

lucy 18957348763 73

tom 13605054400 113

输入样例7:

错误的菜品记录和桌号记录,用户丢弃。例如:

东坡肉 25 T

油淋生菜 9

table 1 : tom 136050540 2023/5/1 12/30/00

2 东坡肉 3 2 1

end

输出样例7:

在这里给出相应的输出。例如:

wrong format

wrong format

 

 

源码如下:

 

import java.util.*;

 

class Dish {

String name;

String flavorType;

int unit_price;

 

public Dish(String name, String flavorType, int unit_price) {

    this.name = name;

    this.flavorType = flavorType;

    this.unit_price = unit_price;

}

 

public int getPrice(int portion) {

    double price = unit_price;

    if (portion == 2) {

        price *= 1.5;

    } else if (portion == 3) {

        price *= 2;

    }

    return (int) Math.round(price);

}

}

 

class Menu {

List<Dish> dishes;

 

public Menu() {

    dishes = new ArrayList<>();

}

 

public void addDish(String name, String flavorType, int unit_price) {

    dishes.add(new Dish(name, flavorType, unit_price));

}

 

public Dish searchDish(String dishName) {

    for (Dish dish : dishes) {

        if (dish.name.equals(dishName)) {

            return dish;

        }

    }

    return null;

}

}

 

class Record {

int orderNum;

Dish dish;

int portion;

int num;

 

public Record(int orderNum, Dish dish, int portion, int num) {

    this.orderNum = orderNum;

    this.dish = dish;

    this.portion = portion;

    this.num = num;

}

 

public int getPrice() {

    return dish.getPrice(portion) * num;

}

}

 

class Order {

List<Record> records;

 

public Order() {

    records = new ArrayList<>();

}

 

public void addRecord(int orderNum, Dish dish, int portion, int num) {

    records.add(new Record(orderNum, dish, portion, num));

}

 

public void deleteRecord(int orderNum) {

    for (int i = 0; i < records.size(); i++) {

        if (records.get(i).orderNum == orderNum) {

            records.remove(i);

            return;

        }

    }

    System.out.println("delete error");

}

 

public int getTotalPrice() {

    int totalPrice = 0;

    for (Record record : records) {

        totalPrice += record.getPrice();

    }

    return totalPrice;

}

}

 

class Customer {

String name;

String phoneNumber;

 

public Customer(String name, String phoneNumber) {

    this.name = name;

    this.phoneNumber = phoneNumber;

}

}

 

public class Main {

public static void main(String[] args) {

Scanner scanner = new Scanner(System.in);

Menu menu = new Menu();

Map<Integer, Order> orders = new TreeMap<>();

Map<String, Integer> customerPayments = new HashMap<>();

 

    while (scanner.hasNextLine()) {

        String line = scanner.nextLine();

        if (line.equals("end")) {

            break;

        }

        if (line.startsWith("table")) {

            String[] tableInfo = line.split(" ");

            int tableNum = Integer.parseInt(tableInfo[1]);

            String name = tableInfo[3];

            String phoneNumber = tableInfo[4];

            Customer customer = new Customer(name, phoneNumber);

            Order currentOrder = new Order();

            orders.put(tableNum, currentOrder);

            customerPayments.put(customer.name + " " + customer.phoneNumber, 0);

        } else if (line.contains("delete")) {

            int orderNum = Integer.parseInt(line.split(" ")[0]);

            Object tableNum = null;

                                                       Order currentOrder = orders.get(tableNum);

            currentOrder.deleteRecord(orderNum);

        } else if (line.contains("T")) {

            String[] dishInfo = line.split(" ");

            String dishName = dishInfo[0];

            String flavorType = dishInfo[1];

            int unit_price = Integer.parseInt(dishInfo[2]);

            menu.addDish(dishName, flavorType, unit_price);

        } else {

            String[] recordInfo = line.split(" ");

            int orderNum = Integer.parseInt(recordInfo[0]);

            String dishName = recordInfo[1];

            int portion = Integer.parseInt(recordInfo[2]);

            int num = Integer.parseInt(recordInfo[3]);

            Dish dish = menu.searchDish(dishName);

            if (dish == null) {

                System.out.println(dishName + " does not exist");

                continue;

            }

            Order currentOrder = null;

                                                       currentOrder.addRecord(orderNum, dish, portion, num);

        }

    }

 

    for (Map.Entry<Integer, Order> entry : orders.entrySet()) {

        int tableNum = entry.getKey();

        Order order = entry.getValue();

        int totalPrice = order.getTotalPrice();

        int finalPrice = calculateFinalPrice(tableNum, totalPrice);

        System.out.println("table " + tableNum + ": " + totalPrice + " " + finalPrice);

    }

 

    for (Map.Entry<String, Integer> entry : customerPayments.entrySet()) {

        String customerInfo = entry.getKey();

        int payment = entry.getValue();

        System.out.println(customerInfo + " " + payment);

    }

}

 

public static int calculateFinalPrice(int tableNum, int totalPrice) {

    int finalPrice;

    if (isOpeningHours(tableNum)) {

        finalPrice = (int) Math.round(totalPrice * getDiscountRate(tableNum));

    } else {

        finalPrice = totalPrice;

    }

    return finalPrice;

}

 

public static boolean isOpeningHours(int tableNum) {

    // 判断是否在营业时间内

    // 周一至周五晚上(17:00-20:30)8折,周一至周五中午(10:30-14:30)6折,周末全价

    // 根据桌号的时间信息判断是否在营业时间内

    return true; // 这里需要根据具体的判断条件进行实现

}

 

public static double getDiscountRate(int tableNum) {

    // 根据桌号的时间信息返回折扣率

    // 周一至周五晚上(17:00-20:30)8折,周一至周五中午(10:30-14:30)6折,周末全价

    return 1.0; // 这里需要根据具体的判断条件返回对应的折扣率

}

}

 

 

这次题目也是菜单,输入的方法与上次题目一致,该代码通过读取用户输入的菜单和订单信息,进行解析和处理,最后输出订单信息和统计信息。它实现了简单的餐厅订单管理功能。

 

7-1 测验1-圆类设计

分数 12

全屏浏览题目

切换布局

作者 段喜龙

单位 南昌航空大学

创建一个圆形类(Circle),私有属性为圆的半径,从控制台输入圆的半径,输出圆的面积

输入格式:

输入圆的半径,取值范围为(0,+∞),输入数据非法,则程序输出Wrong Format,注意:只考虑从控制台输入数值的情况

输出格式:

输出圆的面积(保留两位小数,可以使用String.format(“%.2f”,输出数值)控制精度)

输入样例:

在这里给出一组输入。例如:

2.35

输出样例:

在这里给出相应的输出。例如:

17.35

 

源码如下:

import java.util.Scanner;

 

public class Main {

   

    public static void main(String[] args) {

       Scanner sc = new Scanner(System.in);

       double input = sc.nextDouble();

       Circle c = new Circle(input);

       double out = c.getArea();

       System.out.println(String.format("%.2f", out));

    }

 

}

class Circle {

   

    public double radium;

   

    public Circle(double radium){

       this.radium=radium;

    }

   

    public double getArea() {

       return 3.1415926535*radium*radium;

    }

 

}

 

很简单,不多说。

 

7-2 测验2-类结构设计

分数 18

全屏浏览题目

切换布局

作者 段喜龙

单位 南昌航空大学

设计一个矩形类,其属性由矩形左上角坐标点(x1,y1)及右下角坐标点(x2,y2)组成,其中,坐标点属性包括该坐标点的X轴及Y轴的坐标值(实型数),求得该矩形的面积。类设计如下图:


输入格式:

分别输入两个坐标点的坐标值x1,y1,x2,y2。

输出格式:

输出该矩形的面积值(保留两位小数)。

输入样例:

在这里给出一组输入。例如:

6 5.8 -7 8.9

输出样例:

在这里给出相应的输出。例如:

40.30

 

 

源码如下:


import java.util.Scanner;

public class Rectangle {
private double x1;
private double y1;
private double x2;
private double y2;

public Rectangle() {
    Scanner scanner = new Scanner(System.in);
    x1 = scanner.nextDouble();
    y1 = scanner.nextDouble();
    x2 = scanner.nextDouble();
    y2 = scanner.nextDouble();
}
 
public double getArea() {
    return Math.abs(x2 - x1) * Math.abs(y2 - y1);
}
 
public static void main(String[] args) {
    Rectangle rectangle = new Rectangle();
    System.out.println(String.format("%.2f", rectangle.getArea()));
}

}

 

也还简单

 

7-3 测验3-继承与多态

分数 30

全屏浏览题目

切换布局

作者 段喜龙

单位 南昌航空大学

将测验1与测验2的类设计进行合并设计,抽象出Shape父类(抽象类),Circle及Rectangle作为子类,类图如下所示:


试编程完成如上类图设计,主方法源码如下(可直接拷贝使用):

    public static void main(String[] args) {

        // TODO Auto-generated method stub

        Scanner input = new Scanner(System.in);

       

        int choice = input.nextInt();

       

        switch(choice) {

        case 1://Circle

            double radiums = input.nextDouble();

            Shape circle = new Circle(radiums);

            printArea(circle);

            break;

        case 2://Rectangle

            double x1 = input.nextDouble();

            double y1 = input.nextDouble();

            double x2 = input.nextDouble();

            double y2 = input.nextDouble();

           

            Point leftTopPoint = new Point(x1,y1);

            Point lowerRightPoint = new Point(x2,y2);

           

            Rectangle rectangle = new Rectangle(leftTopPoint,lowerRightPoint);

           

            printArea(rectangle);

            break;

        }

       

    }

其中,printArea(Shape shape)方法为定义在Main类中的静态方法,体现程序设计的多态性。

输入格式:

输入类型选择(1或2,不考虑无效输入)
对应图形的参数(圆或矩形)

输出格式:

图形的面积(保留两位小数)

输入样例1:

1

5.6

输出样例1:

在这里给出相应的输出。例如:

98.52

输入样例2:

2

5.6

-32.5

9.4

-5.6

输出样例2:

在这里给出相应的输出。例如:

102.22

源码如下:

 

import java.util.Scanner;

 

abstract class Shape {

abstract double getArea();

}

 

class Circle extends Shape {

private double radius;

 

public Circle(double radius) {

    this.radius = radius;

}

 

double getArea() {

    return Math.PI * Math.pow(radius, 2);

}

}

 

class Point {

private double x;

private double y;

 

public Point(double x, double y) {

    this.x = x;

    this.y = y;

}

 

public double getX() {

    return x;

}

 

public double getY() {

    return y;

}

}

 

class Rectangle extends Shape {

private Point leftTopPoint;

private Point lowerRightPoint;

 

public Rectangle(Point leftTopPoint, Point lowerRightPoint) {

    this.leftTopPoint = leftTopPoint;

    this.lowerRightPoint = lowerRightPoint;

}

 

double getArea() {

    double width = Math.abs(lowerRightPoint.getX() - leftTopPoint.getX());

    double height = Math.abs(lowerRightPoint.getY() - leftTopPoint.getY());

    return width * height;

}

}

 

public class Main {

public static void printArea(Shape shape) {

System.out.println(String.format("%.2f", shape.getArea()));

}

 

public static void main(String[] args) {

    Scanner input = new Scanner(System.in);

 

    int choice = input.nextInt();

 

    switch (choice) {

        case 1:// Circle

            double radius = input.nextDouble();

            Shape circle = new Circle(radius);

            printArea(circle);

            break;

        case 2:// Rectangle

            double x1 = input.nextDouble();

            double y1 = input.nextDouble();

            double x2 = input.nextDouble();

            double y2 = input.nextDouble();

 

            Point leftTopPoint = new Point(x1, y1);

            Point lowerRightPoint = new Point(x2, y2);

 

            Shape rectangle = new Rectangle(leftTopPoint, lowerRightPoint);

 

            printArea(rectangle);

            break;

    }

}

}

这道题有难度的,除了main方法之外,还定义了其他类和方法。Shape是一个抽象类,其中定义了一个抽象方法area(),表示计算形状的面积。Circle和Rectangle类分别继承了Shape类,并实现了area()方法来计算圆形和矩形的面积。

 

另外,还定义了一个Point类,用于表示坐标点。Circle类和Rectangle类中分别使用了Point对象来表示圆心和矩形的两个顶点。

 

7-4 测验4-抽象类与接口

分数 40

全屏浏览题目

切换布局

作者 段喜龙

单位 南昌航空大学

在测验3的题目基础上,重构类设计,实现列表内图形的排序功能(按照图形的面积进行排序)。
提示:题目中Shape类要实现Comparable接口。

其中,Main类源码如下(可直接拷贝使用):

public class Main {

    public static void main(String\[\] args) {

        // TODO Auto-generated method stub

        Scanner input = new Scanner(System.in);

        ArrayList<Shape> list = new ArrayList<>();   

 

        int choice = input.nextInt();

 

        while(choice != 0) {

            switch(choice) {

            case 1://Circle

                double radiums = input.nextDouble();

                Shape circle = new Circle(radiums);

                list.add(circle);

                break;

            case 2://Rectangle

                double x1 = input.nextDouble();

                double y1 = input.nextDouble();

                double x2 = input.nextDouble();

                double y2 = input.nextDouble();           

                Point leftTopPoint = new Point(x1,y1);

                Point lowerRightPoint = new Point(x2,y2);

                Rectangle rectangle = new Rectangle(leftTopPoint,lowerRightPoint);

                list.add(rectangle);

                break;

            }

            choice = input.nextInt();

        }   

 

        list.sort(Comparator.naturalOrder());//正向排序

 

        for(int i = 0; i < list.size(); i++) {

            System.out.print(String.format("%.2f", list.get(i).getArea()) + " ");

        }   

    }   

}

 

输入格式:

输入图形类型(1:圆形;2:矩形;0:结束输入)

输入图形所需参数

输出格式:

按升序排序输出列表中各图形的面积(保留两位小数),各图形面积之间用空格分隔。

输入样例:

在这里给出一组输入。例如:

1

2.3

2

3.2

3

6

5

1

2.3

0

输出样例:

在这里给出相应的输出。例如:

5.60 16.62 16.62

 

源码如下:

 

import java.util.ArrayList;

import java.util.Comparator;

import java.util.Scanner;

 

abstract class Shape implements Comparable<Shape> {

abstract double getArea();

 

 

public int compareTo(Shape shape) {

    return Double.compare(this.getArea(), shape.getArea());

}

}

 

class Circle extends Shape {

private double radius;

 

public Circle(double radius) {

    this.radius = radius;

}

 

 

double getArea() {

    return Math.PI * Math.pow(radius, 2);

}

}

 

class Point {

private double x;

private double y;

 

public Point(double x, double y) {

    this.x = x;

    this.y = y;

}

 

public double getX() {

    return x;

}

 

public double getY() {

    return y;

}

}

 

class Rectangle extends Shape {

private Point leftTopPoint;

private Point lowerRightPoint;

 

public Rectangle(Point leftTopPoint, Point lowerRightPoint) {

    this.leftTopPoint = leftTopPoint;

    this.lowerRightPoint = lowerRightPoint;

}

 

 

double getArea() {

    double width = Math.abs(lowerRightPoint.getX() - leftTopPoint.getX());

    double height = Math.abs(lowerRightPoint.getY() - leftTopPoint.getY());

    return width * height;

}

}

 

public class Main {

public static void main(String[] args) {

Scanner input = new Scanner(System.in);

ArrayList<Shape> list = new ArrayList<>();

 

    int choice = input.nextInt();

 

    while (choice != 0) {

        switch (choice) {

            case 1:// Circle

                double radius = input.nextDouble();

                Shape circle = new Circle(radius);

                list.add(circle);

                break;

            case 2:// Rectangle

                double x1 = input.nextDouble();

                double y1 = input.nextDouble();

                double x2 = input.nextDouble();

                double y2 = input.nextDouble();

 

                Point leftTopPoint = new Point(x1, y1);

                Point lowerRightPoint = new Point(x2, y2);

 

                Shape rectangle = new Rectangle(leftTopPoint, lowerRightPoint);

                list.add(rectangle);

                break;

        }

        choice = input.nextInt();

    }

 

    list.sort(Comparator.naturalOrder());// 正向排序

 

    for (int i = 0; i < list.size(); i++) {

        System.out.print(String.format("%.2f", list.get(i).getArea()) + " ");

    }

}

}

 

在考试的时候有点紧张,这道题目花了很久时间才完全写对,

 

这道题目要求设计一个类结构,实现对圆形和矩形的面积计算和排序功能。首先,需要定义一个抽象类Shape,其中包含一个抽象方法getArea()用于计算图形的面积,并实现Comparable接口,以便后续进行排序。然后,创建Circle和Rectangle类作为Shape的子类,分别实现getArea()方法来计算圆形和矩形的面积。

 

在Main类中,首先创建一个ArrayList<Shape>来存储输入的图形对象。然后,通过输入的选择,判断是创建圆形对象还是矩形对象,并将其添加到列表中。当输入为0时,结束输入。最后,使用list.sort()方法对列表进行排序,排序依据是图形的面积大小。最后,遍历列表,输出每个图形的面积。

 

这道题目考察了抽象类、继承、多态、接口和集合的使用。通过设计合理的类结构和使用多态,可以实现对不同图形对象的统一处理和排序功能。

 

改进建议

在测验1中,可以添加输入验证的逻辑,确保输入的半径为有效值(大于0)。

在测验2中,可以添加输入验证的逻辑,确保输入的坐标点为有效值。

在测验3中,可以将Shape类改为抽象类,并在其中添加一个抽象方法getArea(),以便子类进行实现。这样可以更好地体现面向对象的特性。

在测验4中,可以将输入的图形类型选择改为循环输入,直到输入0为止。这样可以允许用户输入多个图形进行排序。

在测验4中,可以添加对用户输入的选择的有效性验证,确保输入的选择为1或2

 

总结

 

以上题目涵盖了面向对象的基本概念和应用,包括类的设计、继承、多态、抽象类、接口、集合和异常处理等。通过完成这些题目,可以加深对这些概念的理解和应用能力。

 

在测验1中,设计了一个简单的圆形类,通过输入半径计算圆的面积。这个题目主要考察了类的基本设计和属性的封装。

 

在测验2中,设计了一个矩形类,通过输入左上角和右下角的坐标计算矩形的面积。这个题目主要考察了类之间的关系和属性的使用。

 

在测验3中,将测验1和测验2的类设计进行合并,抽象出Shape父类,并实现了多态性。这个题目主要考察了继承和多态的使用。

 

在测验4中,对测验3进行了扩展,添加了图形的排序功能。这个题目主要考察了抽象类、接口和集合的使用,以及对多个对象进行排序的能力。

 

通过完成以上题目,可以加深对面向对象的理解,并提升面向对象的设计和编程能力。同时,还可以熟悉Java语言的基本语法和常用类的使用。

 

Java的学习之路还很漫长,还需不懈努力。

标签:输出,int,double,BLOG,table,空格,public
From: https://www.cnblogs.com/lyh971433/p/17517247.html

相关文章

  • BLOG-2
    一、前言(要写3000个字还是很累的,希望互评能给高点分,我给所有人都是95以上的!)对于pta4和pta5不想多说,点菜系列巅峰之作两题难度都非常大,而且很复杂,写很多次也没啥分,题量也大关于期中考试,难度到不大,主要考察继承多态接口什么的,题量还可以,就是要在规定时间内写完有点紧张二......
  • BLOG-2
    考试分析:个人感觉本次考试难度偏简单,也无需注意些什么,只要仔细读题问题应该都不大; 1.创建一个圆形类(Circle),私有属性为圆的半径,从控制台输入圆的半径,输出圆的面积输入格式:输入圆的半径,取值范围为(0,+∞),输入数据非法,则程序输出WrongFormat,注意:只考虑从控制台输入数值的情况......
  • BLOG2-PTA题目集4、5以及期中考试
    (1)前言本次博客主要涵盖了Java题目的几个主要知识点,包括:1.面向对象的基础知识:这部分主要包括了类和对象的基本概念,构造方法,访问权限和成员变量的相关内容。在面向对象编程中,对这些基础知识的理解至关重要。2.面向对象的设计原则:这个题目强调了两个重要的设计原则,即继承和组......
  • BLOG-2
    前言:这两次PTA4与5都是菜单计价系统的续集,并且都是PTA3的不同迭代的代码,所以需要对PTA3进行不同的修改来完成题目要求。PTA4:由于时间等诸多原因,我并没有完成PTA4上的任务,并且没有在PTA4上及时的提交代码,所以我无法附上我PTA4的源码,但是我将对菜单计价系统4的题目进行分析设计,......
  • Blog - 2
    前言题目量和难度我觉得觉得作业题量适中,不会太多也不会太少,能让我练习。这次大作业,一共三道题。第一题和第三题难度不大,但是第二题是点菜系列的题目,这道题占了70分,而我只拿到了60分。在期中考中,虽然有三道题,但难度不算太大,每一道题都是在前一道题的基础上稍加修改即可。实验一......
  • oo第二次BLOG
    一:总结  pta4,5和期中的作业其实主要用于对所学知识的练习,第六次作业只有一到成绩题目有一定的难度,后两次作业的题目这相对简单一些。作业尽力去完成,虽然有些不完美,但已经尽了全力。七,八次作业折相对简单一些,完成情况也相对好一点。二:作业实现7-1菜单计价程序-4......
  • 菜单4、5以及期中考试总结-BLOG-PTA-4、5
    22201612-刘健涛目录(1)前言(2)设计与分析(3)踩坑心得(4)改进建议(5)总结正文(1)前言  (2)设计与分析(3)踩坑心得(4)改进建议(5)总结......
  • BLOG-2
    一、题目集分析本次博客将对PTA的第四,五次题目集和期中考试的题目进行分析,情况如下:(1)题量分析:第四次练习共计1题期中考试共计4题第五次练习共计1题从题量而言,数量适中。(2)知识点分析:第四次题目集继续为菜单的续集,对菜单的难度进行增加,主要体现在对异常信息的处......
  • BLOG_OOP_期中考试
    前言涉及知识点1.对于创建对象和类的初步实践;如构建圆类和矩形类;1.对于抽象类和继承与多态的认识;如构建shape类;题量不多,可以完成。难度不大,可以完成。设计与分析题目源码如下importjava.util.*;publicclassMain{publicstaticvoidmain(String[]......
  • blog2
    第四次题目集7-1菜单计价程序-4分数100作者蔡轲单位南昌航空大学本体大部分内容与菜单计价程序-3相同,增加的部分用加粗文字进行了标注。设计点菜计价程序,根据输入的信息,计算并输出总价格。输入内容按先后顺序包括两部分:菜单、订单,最后以"end"结束。菜单由一条或多条菜品记......