首页 > 其他分享 >PTA 4,5题目集及期中考试总结

PTA 4,5题目集及期中考试总结

时间:2023-06-30 19:12:43浏览次数:52  
标签:输出 期中考试 格式 PTA 空格 英文 new input 集及

PTA 4,5题目集及期中考试总结

前言

第4次题目集

知识点:对象和类的创建和应用,字符串的创建和应用。

总共有1题,难度偏高。

第5次题目集

知识点:对象和类的创建和应用,字符串的创建和应用。

总共有1题,难度偏高。

期中考试

知识点:字符的处理,类的封装,接口的创建和使用。

总共有4题,难度偏低,比较基础。

正文

第4次题目集

这次题目集虽然只有一题,但这题对我来说很难,我缺少能力完成它。

7-1 菜单计价程序-4

看到这题时我有些被吓住了,对当时java仅仅只是初步掌握的我来说,写如此复杂的程序是很困难的,其中有太多我不了解的内容。我这题写的很不好,只拿到一些基础分。

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

本次课题比菜单计价系列-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折, 周末全价。

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

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

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

import java.util.*;

import java.lang.*;

 class Main {

public static void main(String[] args) {

Scanner input=new Scanner(System.in);

String name,t,t1,t2,menu;

int price,i=0,portion,table,number,num,allprice=0;

String[] m;

Dish[] dish=new Dish[5];

name=input.next();

while(!name.equals("T"))

{

price=input.nextInt();

dish[i]=new Dish(name,price);

i++;

name=input.next();

}

 

 

t1=input.nextLine();

 

String[] day=t1.split("[/,]");

        //table=Integer.parseInt(day[1]);

menu=input.nextLine();

while(!menu.equals("end"))

{

 

/*m=menu.split("");

number=Integer.parseInt(m[0]);

//name=m[1];

if(m[1].equals("delete"))continue;

else {

portion=Integer.parseInt(m[2]);

num=Integer.parseInt(m[3]);

for(int j=0;j<=i;j++)

{

if(m[1].equals(dish[j].name))

{

allprice+=dish[j].getprice(portion,num);

}

}

}*/

            menu=input.nextLine();

}

        System.out.println("wrong format");

//System.out.println("table "+table+":");

}

}

class Dish{

String name;

int price;

Dish()

{

 

}

Dish(String name,int price)

{

this.name=name;

this.price=price;

}

public int getprice(int portion,int num)

{

int p=0;

if(portion==1)p=price;

else if(portion==2)p=(int) Math.round(price*1.5);

else if(portion==3)p=price*2;

return p*num;

}

}

 

第5次题目集

这次题目集也只有一题,很难的一题。

7-1 菜单计价程序-5

与上一题一样,这题我写的很差。当初的我有太多不足,也没有前面的激情和基础,无法完成这道题目。

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

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

 

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

 

 

以上为菜单计价系列-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份川菜,辣度分别是1、3、5;还有4份晋菜,酸度分别是,1、1、2、2,辣度平均值为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位,前三位必须是180、181、189、133、135、136其中之一。

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

输出用户支付金额格式:

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

 

 

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

 

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

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

输入格式:

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

 

菜品记录格式:

 

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

 

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

 

import java.util.*;

import java.lang.*;

 class Main {

public static void main(String[] args) {

Scanner input=new Scanner(System.in);

String name,t,t1,t2,menu;

int price,i=0,portion,table,number,num,allprice=0;

String[] m;

Dish[] dish=new Dish[5];

/*name=input.next();

while(!name.equals("T"))

{

price=input.nextInt();

dish[i]=new Dish(name,price);

i++;

name=input.next();

}

 

 

t1=input.nextLine();

 

String[] day=t1.split("[/,]");

        //table=Integer.parseInt(day[1]);*/

menu=input.nextLine();

while(!menu.equals("end"))

{

 

/*m=menu.split("");

number=Integer.parseInt(m[0]);

//name=m[1];

if(m[1].equals("delete"))continue;

else {

portion=Integer.parseInt(m[2]);

num=Integer.parseInt(m[3]);

for(int j=0;j<=i;j++)

{

if(m[1].equals(dish[j].name))

{

allprice+=dish[j].getprice(portion,num);

}

}

}*/

            menu=input.nextLine();

}

        //System.out.println("table 1 out of opening hours");

        System.out.println("wrong format");

        System.out.println("wrong format");

//System.out.println("table "+table+":");

}

}

class Dish{

String name;

int price;

Dish()

{

 

}

Dish(String name,int price)

{

this.name=name;

this.price=price;

}

public int getprice(int portion,int num)

{

int p=0;

if(portion==1)p=price;

else if(portion==2)p=(int) Math.round(price*1.5);

else if(portion==3)p=price*2;

return p*num;

}

}

 

 

期中考试

我没有权限访问期中考试的题目,也找不到以前的代码,只能依靠一些记忆了。

写这些题目时我已经有一段时间没写java了,所以我写得很慢,浪费了不少时间,导致我最后一题时间不足。这些题目比较基础,可我还是仅仅及格。考完后,老师在课堂上讲解了这些题目,我也在课上收获了不少,初步了解了接口的使用方法。

7-1 测验1-圆类设计

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

注意保留几位小数,不然过不了。圆周率是3.1415926525。。。。。,也可以用Math.PI表示。

 

import java.util.*;

public class Main {

 

public static void main(String[] args) {

// TODO Auto-generated method stub

Scanner in=new Scanner(System.in);

double a=in.nextDouble(),b;

b=a*a*Math.PI;

if(a>0)System.out.printf("%.2f", b);

else System.out.printf("Wrong Format");

 

}

 

}

 

 

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

很简单的一题,需要注意x1-x2和y1-y2的正负。

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

 

import java.util.*;

public class Main {

 

public static void main(String[] args) {

// TODO Auto-generated method stub

Scanner in=new Scanner(System.in);

 

double x2,x1,y1,y2,s;

x1=in.nextDouble();

y1=in.nextDouble();

x2=in.nextDouble();

y2=in.nextDouble();

s=Math.abs(x1-x2)*Math.abs(y1-y2);

System.out.printf("%.2f", s);

}
}

 

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

这是一道面向对象程序编程题,不难,但需要仔细。

将测验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类中的静态方法,体现程序设计的多态性。

 

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

写这题时,我开始看错了题目,没找到关键点接口,只是用以前学的方法排序,浪费了时间,只剩给我10分钟左右,让我没写出来。

在测验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()) + " ");

        }    

    }    

}

 

总结

在这两次题目集和期中考试中,我有了一些进步,但还不够,我在接口方面还有许多不足,我需要努力掌握这些知识,希望我能在以后的学习中更进一步。最后,我希望老师能增加课堂互动和实例讲解,对学生掌握知识点有帮助。

 

标签:输出,期中考试,格式,PTA,空格,英文,new,input,集及
From: https://www.cnblogs.com/hanling16/p/17517633.html

相关文章

  • 4-5次PTA题目总结blog
    前言:题目集1~3的知识点、题量、难度等情况如下:知识点:JAVA基础,基础算法,面向对象程序设计题量:共计2道题目难度:题目从易到难,逐层递进,分别为考察Java各个类的理解、掌握与运用。设计与分析:1importjava.text.ParseException;2importjava.time.DateTimeExce......
  • iptables是如何影响数据包的传输的?
    iptables的表和链iptables可以设置不同的规则,并且它把规则按用途进行分类,分成了4个表,分别是表用途raw表用于去除数据包上的连接追踪机制(ConnectionTracking)。mangle表用于修改数据包的报文头信息,比如服务类型(TypeOfService,ToS)、生存周期(TimetoLive,TTL)。n......
  • Java PTA第4~5次题目集总结以及期中考试总结
    一.前言1.第四次题目集的知识点涉及Time类以及前面学的各种知识点;题量很少只有一题;难度比较大。2.第五次题目集的知识点主要是Time类、异常处理等等;题量很少只有一题;难度比较大。3.期中考试的知识点涉及类、继承与多态、接口等等;题量不多,一共4题;整体难度不高。二.设计与分析7......
  • BLOG2-PTA题目集4、5以及期中考试
    (1)前言本次博客主要涵盖了Java题目的几个主要知识点,包括:1.面向对象的基础知识:这部分主要包括了类和对象的基本概念,构造方法,访问权限和成员变量的相关内容。在面向对象编程中,对这些基础知识的理解至关重要。2.面向对象的设计原则:这个题目强调了两个重要的设计原则,即继承和组......
  • 4、5及期中考试总结
    一.前言Java编程语言是当今最流行的编程语言之一,由于其跨平台性、面向对象性和安全性等特点,受到广泛的应用。作为一名计算机专业的学生,在学习Java编程语言时,我们需要完成多个作业来巩固所学知识。在前三次Java作业中,我们已经学习了Java的基础知识和常用技术,通过完成这些作业,我们......
  • 菜单4、5以及期中考试总结-BLOG-PTA-4、5
    22201612-刘健涛目录(1)前言(2)设计与分析(3)踩坑心得(4)改进建议(5)总结正文(1)前言  (2)设计与分析(3)踩坑心得(4)改进建议(5)总结......
  • 4-5次及期中考试PTA题目总结
    前言 第四次和第五次pta每次都只有一道题目,分别是菜单计价4和菜单计价5,没有了其他小题pta拿起分来变得困难了许多。不过好在题目要求上菜单计价4和菜单计价5只是菜单计价3的两个分支,没有太多需要叠加的功能,避免的题目过于的复杂。 第四次的菜单计价在菜单计价三的基础上没有加......
  • PTA4-5及期中总结
    (1)前言期中考试的题目集总体来说还是很简单的,题目量比较少而且难度偏易,考察的知识点可以说是很基础的面向对象编程知识点,基本上就是在考验我们的基本功扎不扎实,对于知识点很熟悉的同学可以很快的完成大部分题目,但是还有个接口题目,需要使用java自带类,这题先前没有遇到过就会做......
  • BLOG_OOP_期中考试
    前言涉及知识点1.对于创建对象和类的初步实践;如构建圆类和矩形类;1.对于抽象类和继承与多态的认识;如构建shape类;题量不多,可以完成。难度不大,可以完成。设计与分析题目源码如下importjava.util.*;publicclassMain{publicstaticvoidmain(String[]......
  • pta题目集4~5及期中考试总结性blog
    一、前言总结三次题目集的知识点、题量、难度等情况第四次题目集主要更新了各种异常情况,是对代码正确度的深入考察,涉及时间的格式问题,信息的格式问题各种格式问题等等,涉及到hashset、面向对象编程的封装性、BigDecimal类关于精确小数的运算以及了解Scanner类中nextLine()等方法......