一.前言
前三次题目集总的来说知识点很多,题量也很大,除了第一次题目简单,第二三次题目的难度跨度太大了,第一次都是很基础的题目,第二三次题目难度突然提高很多,措不及防,完成得很困难,由于菜单计价系统是第一次写,难度很大,完成的不太好。
二.设计与分析
第一次题目集:
总的来说,第一次题目集难度不大,其中大部分内容与上学期学的c语言很类似,容易上手,没有什么地方需要分析与解释的。
第二次题目集
7-1 菜单计价程序-1
某饭店提供4种菜,每种菜品的基础价格如下:
西红柿炒蛋 15
清炒土豆丝 12
麻婆豆腐 12
油淋生菜 9
设计点菜计价程序,根据输入的订单,计算并输出总价格。
订单由一条或多条点菜记录组成,每条记录一行,最后以"end"结束
每条点菜记录包含:菜名、份额两个信息。
份额可选项包括:1、2、3,分别代表小、中、大份)
不同份额菜价的计算方法:
小份菜的价格=菜品的基础价格。
中份菜的价格=菜品的基础价格1.5。
小份菜的价格=菜品的基础价格2。
如果计算出现小数,按四舍五入的规则进行处理。
参考以下类的模板进行设计:
菜品类:对应菜谱上一道菜的信息。
Dish {
String name;//菜品名称
int unit_price; //单价
int getPrice(int portion)//计算菜品价格的方法,输入参数是点菜的份额(输入数据只能是1/2/3,代表小/中/大份)
}
菜谱类:对应菜谱,包含饭店提供的所有菜的信息。
Menu {
Dish[] dishs ;//菜品数组,保存所有菜品信息
Dish searthDish(String dishName)//根据菜名在菜谱中查找菜品信息,返回Dish对象。
}
点菜记录类:保存订单上的一道菜品记录
Record {
Dish d;//菜品
int portion;//份额(1/2/3代表小/中/大份)
int getPrice()//计价,计算本条记录的价格
}
订单类:保存用户点的所有菜的信息。
Order {
Record[] records;//保存订单上每一道的记录
int getTotalPrice()//计算订单的总价
Record addARecord(String dishName,int portion)
//添加一条菜品信息到订单中。
}
输入格式:
每条点菜记录的格式:
菜名+空格(英文)+份额
注:份额可输入(1/2/3), 1代表小份,2代表中份,3代表大份。
最后一条记录以“end”结束。
输出格式:
订单上所有菜品的总价(整数数值),每份菜
如果订单中包含不能识别的菜名,则在总价之前输出“** does not exist”,**是不能识别的菜名
输入样例:
在这里给出一组输入。例如:
麻婆豆腐 2
西红柿炒蛋 3
end
输出样例:
在这里给出相应的输出。例如:
48
输入样例1:
订单中包含不存在的菜品记录。例如:
麻婆豆腐 2
炒脆肚 2
西红柿炒蛋 3
end
输出样例1:
在这里给出相应的输出。例如:
炒脆肚 does not exist
48
附上源码
import java.util.Scanner;
public class Die {
public static void main(String[] args){
Scanner in = new Scanner(System.in);
int y;
int j=0;
String x = in.next();
Order z = new Order();
Menu n = new Menu();
while(!x.equals("end"))
{
y=in.nextInt();
z.records[j] = new Record();
z.records[j] = z.addARecord(x,y);
j++;
x=in.next();
}
for(int i=0;i<j;i++)
{
z.records[i].d=n.searthDish(z.records[i].d.name);
}
System.out.println(z.getTotalPrice());
}
}
class Dish{
String name;
int unit_price;
int getPrice(int portion){
switch(portion)
{
case 1:return unit_price;
case 2:if(unit_price==15||unit_price==9)return ((int)(unit_price*1.5))+1;
else return unit_price*3/2;
case 3:return unit_price*2;
}
return 0;
}
}
class Record {
int portion;
Dish d=new Dish();
int getPrice()
{
return d.getPrice(portion);
}
}
class Order {
Record[] records=new Record[20];
int sum = 0;
int count = 0;
int getTotalPrice(){
for(int i=0;i<count;i++){
if(records[i].d!=null)
sum+=records[i].getPrice();
}
return sum;
}
Record addARecord(String dishName,int portion){
Record x=new Record();
x.d.name=dishName;
x.portion=portion;
count++;
return x;
}
}
class Menu {
Dish[] dishs = new Dish[10];
Dish searthDish(String dishName){
dishs[0] = new Dish();
dishs[0].name = "西红柿炒蛋";dishs[0].unit_price = 15;
dishs[1] = new Dish();
dishs[1].name = "清炒土豆丝";dishs[1].unit_price = 12;
dishs[2] = new Dish();
dishs[2].name = "麻婆豆腐";dishs[2].unit_price = 12;
dishs[3] = new Dish();
dishs[3].name = "油淋生菜";dishs[3].unit_price = 9;
boolean x = false;
int i=0;
for(i=0;i<4;i++){
if(dishName.equals(dishs[i].name)==true){
x=true;
break;
}
}
if(x==true)
return dishs[i];
else
{
System.out.println(dishName+" does not exist");
return null;
}
}
}
菜单系列的第一道题就给了我当头一棒,打得我措不及防,这道题目涉及到了类与类之间的相互调用,这道题目我共用创建了五个类,分别是Menu菜单,Record记录,Dish菜品,Order点菜,相互调用,完成了这道题。
7-2 菜单计价程序-2
设计点菜计价程序,根据输入的信息,计算并输出总价格。
输入内容按先后顺序包括两部分:菜单、订单,最后以"end"结束。
菜单由一条或多条菜品记录组成,每条记录一行
每条菜品记录包含:菜名、基础价格 两个信息。
订单分:点菜记录和删除信息。每一类信息都可包含一条或多条记录,每条记录一行。
点菜记录包含:序号、菜名、份额、份数。
份额可选项包括:1、2、3,分别代表小、中、大份。
删除记录格式:序号 delete
标识删除对应序号的那条点菜记录。
不同份额菜价的计算方法:
小份菜的价格=菜品的基础价格。
中份菜的价格=菜品的基础价格1.5。
小份菜的价格=菜品的基础价格2。
如果计算出现小数,按四舍五入的规则进行处理。
参考以下类的模板进行设计:
菜品类:对应菜谱上一道菜的信息。
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)//
根据序号查找一条记录
}
输入格式:
菜品记录格式:
菜名+英文空格+基础价格
如果有多条相同的菜名的记录,菜品的基础价格以最后一条记录为准。
点菜记录格式:
序号+英文空格+菜名+英文空格+份额+英文空格+份数
注:份额可输入(1/2/3), 1代表小份,2代表中份,3代表大份。
删除记录格式:序号 +英文空格+delete
最后一条记录以“end”结束。
输出格式:
按顺序输出每条订单记录的处理信息,
每条点菜记录输出:序号+英文空格+菜名+英文空格+价格。其中的价格等于对应记录的菜品*份数,序号是之前输入的订单记录的序号。
如果订单中包含不能识别的菜名,则输出“** does not exist”,**是不能识别的菜名
如果删除记录的序号不存在,则输出“delete error”
最后输出订单上所有菜品的总价(整数数值),
本次题目不考虑其他错误情况,如:菜单订单顺序颠倒、不符合格式的输入、序号重复等。
输入样例:
在这里给出一组输入。例如:
麻婆豆腐
12
油淋生菜
9
1
麻婆豆腐
2 2
2
油淋生菜
1 3
end
输出样例:
在这里给出相应的输出。例如:
1
麻婆豆腐
36
2
油淋生菜
27
63
输入样例1:
订单中包含删除记录。例如:
麻婆豆腐
12
油淋生菜
9
1
麻婆豆腐
2 2
2
油淋生菜
1 3
1 delete
end
输出样例1:
在这里给出相应的输出。例如:
1
麻婆豆腐
36
2
油淋生菜
27
27
输入样例2:
订单中包含不存在的菜品记录。例如:
麻婆豆腐
12
油淋生菜
9
1
麻婆豆腐
2 2
2
油淋生菜
1 3
3
麻辣鸡丝
1 2
end
输出样例2:
在这里给出相应的输出。例如:
1
麻婆豆腐
36
2
油淋生菜
27
麻辣鸡丝
does not exist
63
输入样例3:
订单中包含删除信息以及不存在的菜品记录。例如:
麻婆豆腐
12
油淋生菜
9
1
麻婆豆腐
2 2
2
油淋生菜
1 3
3
麻辣鸡丝
1 2
1 delete
7 delete
end
输出样例3:
在这里给出相应的输出。例如:
1
麻婆豆腐
36
2
油淋生菜
27
麻辣鸡丝
does not exist
delete error;
27
输入样例4:
订单中包含删除信息以及不存在的菜品记录。例如:
麻婆豆腐
12
油淋生菜
9
1
麻婆豆腐
2 2
2
油淋生菜
1 3
3
麻辣鸡丝
1 2
5 delete
7 delete
end
输出样例4:
在这里给出相应的输出。例如:
1
麻婆豆腐
36
2
油淋生菜
27
麻辣鸡丝
does not exist
delete error;
delete error;
63
源码附上:
import java.util.Scanner;
public class Die {
public static void main(String[] args){
Scanner q = new Scanner(System.in);
Order my = new Order();
Menu x = new Menu();
String y="";
String[] z = new String[10];
y = q.nextLine();
int i = 0;
int k = 0;
int a = 0;
int a1= 0;
int a2 = 0;
int a3 = 0;
while(!y.equals("end"))
{
z = y.split(" ");
if(z.length==2&&!z[1].equals("delete"))
{
a = Integer.parseInt(z[1]);
x.dishs[i]=new Dish();
x.dishs[i] = x.addDish(z[0],a);
i++;
}
if(z.length==4)
{
a1 = Integer.parseInt(z[0]);
a2 = Integer.parseInt(z[2]);
a3 = Integer.parseInt(z[3]);
my.records[k] = new Record();
my.records[k] = my.addARecord(a1,z[1],a2,a3);
my.records[k].d=x.searthDish(z[1]);
if(my.records[k].d==null)
System.out.println(z[1]+" does not exist");
else
System.out.println(my.records[k].orderNum+" "+my.records[k].d.name+" "+my.records[k].getPrice());
k++;
}
if(z[1].equals("delete"))
{
a1 = Integer.parseInt(z[0]);
my.delARecordByOrderNum(a1);
}
y = q.nextLine();
}
System.out.println(my.getTotalPrice());
}
}
class Order
{
Record[] records = new Record[10];
int count = 0;
int sum = 0;
int i = 0;
int getTotalPrice()
{
for(i=0;i<count;i++){
if(records[i].d!=null)
sum+=records[i].getPrice();
}
return sum;
}
Record addARecord(int orderNum,String dishName,int portion,int num)
{
Record z=new Record();
z.orderNum = orderNum;
z.d.name=dishName;
z.portion=portion;
z.num = num;
count++;
return z;
}
void delARecordByOrderNum(int orderNum){
if(orderNum<=count)
{
records[orderNum-1].num=0;
}
else
System.out.println("delete error;");
}
}
class Menu
{
Dish[] dishs = new Dish[10];
int t = 0;
Dish searthDish(String dishName)
{
int flag = 0;
int i;
for(i=t-1;i>=0;i--){
if(dishName.equals(dishs[i].name)==true)
{
flag = 1;
break;
}
}
if(flag==1)
return dishs[i];
else
{
return null;
}
}
Dish addDish(String dishName,int unit_price)
{
Dish dish1 =new Dish();
dish1.name = dishName;
dish1.unit_price = unit_price;
t++;
return dish1;
}
}
class Record
{
int orderNum;
Dish d=new Dish();
int portion;
int num;
int getPrice()
{
return num*d.getPrice(portion);
}
}
class Dish
{
String name;
int unit_price;
int getPrice(int portion){
switch(portion)
{
case 1:return unit_price;
case 2:if(unit_price==15||unit_price==9)return ((int)(unit_price*1.5))+1;
else return unit_price*3/2;
case 3:return unit_price*2;
}
return 0;
}
}
菜单计价程序二比一要难上不少,增加了删除菜品的功能,其实结构和一差不多,就是更为复杂,更费脑子,当时感觉自己都快秃头了QwQ
7-1 菜单计价程序-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+英文空格+桌号+“:”+英文空格+当前桌的总价
本次题目不考虑其他错误情况,如:桌号、菜单订单顺序颠倒、不符合格式的输入、序号重复等,在本系列的后续作业中会做要求。
输入格式:
桌号标识格式: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
table 1 2023/3/22 12/2/3
1
麻婆豆腐
2 2
2
油淋生菜
1 3
end
输出样例:
在这里给出相应的输出。例如:
table 1:
1
麻婆豆腐
36
2
油淋生菜
27
table 1: 38
输入样例1:
在这里给出一组输入。例如:
麻婆豆腐
12
油淋生菜
9
table 1 2023/3/22 17/0/0
1
麻婆豆腐
2 2
2
油淋生菜
1 3
1 delete
end
输出样例1:
在这里给出相应的输出。例如:
table 1:
1
麻婆豆腐
36
2
油淋生菜
27
table 1: 22
输入样例2:
在这里给出一组输入。例如:
麻婆豆腐
12
油淋生菜
9
table 1 2023/3/22 16/59/59
1
麻婆豆腐
2 2
2
油淋生菜
1 3
1 delete
end
输出样例2:
在这里给出相应的输出。例如:
table 1:
1
麻婆豆腐
36
2
油淋生菜
27
table 1 out of opening hours
输入样例3:
在这里给出一组输入。例如:
麻婆豆腐
12
油淋生菜
9
table 1 2022/12/5 15/03/02
1
麻婆豆腐
2 2
2
油淋生菜
1 3
3
麻辣鸡丝
1 2
5 delete
7 delete
table 2 2022/12/3 15/03/02
1
麻婆豆腐
2 2
2
油淋生菜
1 3
3
麻辣鸡丝
1 2
7 delete
end
输出样例3:
在这里给出相应的输出。例如:
table 1:
1
麻婆豆腐
36
2
油淋生菜
27
麻辣鸡丝
does not exist
delete error;
delete error;
table 2:
1
麻婆豆腐
36
2
油淋生菜
27
麻辣鸡丝
does not exist
delete error;
table 1 out of opening hours
table 2: 63
输入样例4:
在这里给出一组输入。例如:
麻婆豆腐
12
油淋生菜
9
table 1 2022/12/3 19/5/12
1
麻婆豆腐
2 2
2
油淋生菜
1 3
3
麻辣鸡丝
1 2
table 2 2022/12/3 15/03/02
1
麻婆豆腐
2 2
2
油淋生菜
1 3
3
麻辣鸡丝
1 2
1 4
麻婆豆腐
1 1
7 delete
end
输出样例4:
在这里给出相应的输出。例如:
table 1:
1
麻婆豆腐
36
2
油淋生菜
27
麻辣鸡丝
does not exist
table 2:
1
麻婆豆腐
36
2
油淋生菜
27
麻辣鸡丝
does not exist
4 table 2 pay for table 1 12
delete error;
table 1: 63
table 2: 75
源码附上:
import java.util.ArrayList;
import java.util.Calendar;
import java.util.Date;
import java.util.List;
import java.util.Scanner;
public class Die {
static Scanner scanner = new Scanner(System.in);
public static void main(String[] args) {
Menu menu = new Menu();
Order[] orders = new Order[100];
int orderIdx = 0;
while (scanner.hasNext()) {
String line = scanner.nextLine();
if (line.equals("end")) {
break;
}
String[] parts = line.split(" ");
if (parts[0].equals("table")) {
String[] time = parts[3].split("/");
int year = Integer.parseInt(time[0]);
int month = Integer.parseInt(time[1]);
int day = Integer.parseInt(time[2]);
time = parts[4].split(":");
int hour = Integer.parseInt(time[0]);
int minute = Integer.parseInt(time[1]);
int second = Integer.parseInt(time[2]);
orders[orderIdx] = new Order(Integer.parseInt(parts[1]), year, month, day, hour, minute, second);
orderIdx++;
} else if (parts[1].equals("delete")) {
int orderNum = Integer.parseInt(parts[0]);
Record record = orders[orderIdx - 1].findRecordByNum(orderNum);
if (record == null) {
System.out.println("delete error");
} else {
orders[orderIdx - 1].delARecordByOrderNum(orderNum);
}
} else {
String dishName = parts[1];
Dish dish = menu.searthDish(dishName);
if (dish == null) {
dish = menu.addDish(dishName, Integer.parseInt(parts[2]));
}
int orderNum = Integer.parseInt(parts[0]);
int portion = Integer.parseInt(parts[2]);
int num = Integer.parseInt(parts[3]);
orders[orderIdx -1].addARecord(orderNum, dish, portion, num);
}
}
for (int i = 0; i < orderIdx; i++) {
System.out.println(orders[i].toString());
}
}
public static class Menu {
private List<Dish> dishes;
public Menu() {
dishes = new ArrayList<>();
}
public Dish searthDish(String name) {
for (Dish dish : dishes) {
if (dish.getName().equals(name)) {
return dish;
}
}
return null;
}
public Dish addDish(String name, int price) {
Dish dish = new Dish(name, price);
dishes.add(dish);
return dish;
}
}
public static class Dish {
private String name;
private int price;
public Dish(String name, int price) {
this.name = name;
this.price = price;
}
public String getName() {
return name;
}
public int getPrice() {
return price;
}
}
public static class Order {
private int tableNum;
private List<Record> records;
private Date date;
public Order(int tableNum, int year, int month, int day, int hour, int minute, int second) {
this.tableNum = tableNum;
records = new ArrayList<>();
Calendar calendar = Calendar.getInstance();
calendar.set(year, month - 1, day, hour, minute, second);
}
public void addARecord(int orderNum, Dish dish, int portion, int num) {
Record record = new Record(orderNum, dish, portion, num);
records.add(record);
}
public Record findRecordByNum(int orderNum) {
for (Record record : records) {
if (((Object) record).getOrderNum() == orderNum) {
return record;
}
}
return null;
}
public void delARecordByOrderNum(int orderNum) {
Record record = findRecordByNum(orderNum);
if (record != null) {
records.remove(record);
}
}
public int getTableNum() {
return tableNum;
}
public Date getDate() {
return date;
}
}
}
菜单3比2难度翻倍,让我对Java类的编写和使用有了更深刻的理解。通过这个项目,我学会了如何在Java中创建类、使用列表和日期对象,并实现基本的输入和输出功能。
在编写代码的过程中,我遇到了一些挑战,例如如何正确地解析用户输入、如何在多个类之间传递数据等。通过仔细思考和查阅文档,我逐渐解决了这些问题,并成功地实现了一个简单的点餐系统。
三.踩坑心得
通过这三次pta题目集,我学到了很多:
1. 注意输入格式:在读取用户输入时,需要注意用户输入的格式,特别是日期和时间的格式。在这段代码中,日期和时间的格式是固定的,需要按照指定的格式进行输入,否则会导致程序出错。
2. 熟悉面向对象编程的基本概念:这段代码中涉及到了面向对象编程的一些基本概念,如类、对象、构造函数、方法等。熟悉这些概念对于理解代码的功能和实现非常有帮助。
3. 熟悉集合类的使用:这段代码中使用了List集合来存储菜单和点餐信息,熟悉集合类的使用可以帮助我们更加方便地管理和操作数据。
4. 小心空指针异常:在使用对象时,需要注意空指针异常的问题,尤其是在调用对象的方法时。在这段代码中,如果没有正确地初始化对象,就会导致空指针异常。
5. 学会调试程序:在编写代码时,难免会出现一些错误,学会调试程序可以帮助我们更快地找出问题所在并进行修改。
总之,这段代码是一个很好的面向对象编程的练习题,通过学习和实践,我们可以更好地掌握面向对象编程的相关知识和技能。
四.主要困难和改进建议
主要困难:
1. 变量命名不够规范:在这段代码中,有些变量的命名不够规范,不够清晰明了,比如parts
、num
等,这会给代码的阅读和维护带来一定的困难。
2. 代码可读性不够好:在这段代码中,有些代码的可读性不够好,比如一些复杂的if语句和循环语句,这会让代码难以理解和维护。
改进建议:
1. 规范变量命名:建议使用有意义的变量名,能够清晰地表达变量的含义和作用,提高代码的可读性和可维护性。
2. 提高代码可读性:建议使用更加简洁明了的语句,避免使用过于复杂的语句,增加代码的可读性和可维护性。
五.内容总结
这三次pta题目集帮助我更好地掌握面对编程的相关知识和技能,为我的java之旅打下了良好的基础,培养了独立动手能力,让自己的思维更为敏捷,敢于向难题动手,哪怕耗费一下午,一晚上也不会觉得浪费,只会感觉收获颇丰。
在这也感谢老师的辛勤教导,辛苦老师们了!
标签:油淋,题目,记录,Blog1,PTA,int,菜品,Dish,麻婆豆腐 From: https://www.cnblogs.com/lyh971433/p/17428188.html