首页 > 其他分享 >PTA 阶段性总结

PTA 阶段性总结

时间:2023-06-27 23:44:49浏览次数:41  
标签:总结 阶段性 java String int PTA 空格 课程 name

第一部分 总结PTA

(1)前言:

      在第三阶段中,考察了set,map,hashmap,的方法的使用,同时最主要的考察了和前面菜单计价相似的对成绩的处理和判断,在这一阶段题目的难度不是特别大主要是要求我们对课程上的知识进行运用,学会并且理解用法,来提高我们的代码效率

(2)设计与分析:

      这里我们主要以成绩计算系列的题目来说

       7-1 课程成绩统计程序-1

某高校课程从性质上分为:必修课、选修课,从考核方式上分为:考试、考察。

考试的总成绩由平时成绩、期末成绩分别乘以权重值得出,比如平时成绩权重0.3,期末成绩权重0.7,总成绩=平时成绩*0.3+期末成绩*0.7。

考察的总成绩直接等于期末成绩

必修课的考核方式必须为考试,选修课可以选择考试、考察任一考核方式。

1、输入:

包括课程、课程成绩两类信息。

课程信息包括:课程名称、课程性质、考核方式(可选,如果性质是必修课,考核方式可以没有)三个数据项。

课程信息格式:课程名称+英文空格+课程性质+英文空格+考核方式

课程性质输入项:必修、选修

考核方式输入选项:考试、考察

课程成绩信息包括:学号、姓名、课程名称、平时成绩(可选)、期末成绩

课程信息格式:学号+英文空格+姓名+英文空格+课程名称+英文空格+平时成绩+英文空格+期末成绩

以上信息的相关约束:

1)平时成绩和期末成绩的权重默认为0.3、0.7

2)成绩是整数,不包含小数部分,成绩的取值范围是【0,100】

3)学号由8位数字组成

4)姓名不超过10个字符

5)课程名称不超过10个字符

6)不特别输入班级信息,班级号是学号的前6位。

2、输出:

输出包含三个部分,包括学生所有课程总成绩的平均分、单门课程成绩平均分、单门课程总成绩平均分、班级所有课程总成绩平均分。

为避免误差,平均分的计算方法为累加所有符合条件的单个成绩,最后除以总数。

1)学生课程总成绩平均分按学号由低到高排序输出

格式:学号+英文空格+姓名+英文空格+总成绩平均分

如果某个学生没有任何成绩信息,输出:学号+英文空格+姓名+英文空格+"did not take any exams"

2)单门课程成绩平均分分为三个分值:平时成绩平均分(可选)、期末考试平均分、总成绩平均分,按课程名称的字符顺序输出

格式:课程名称+英文空格+平时成绩平均分+英文空格+期末考试平均分+英文空格+总成绩平均分

如果某门课程没有任何成绩信息,输出:课程名称+英文空格+"has no grades yet"

3)班级所有课程总成绩平均分按班级由低到高排序输出

格式:班级号+英文空格+总成绩平均分

如果某个班级没有任何成绩信息,输出:班级名称+英文空格+ "has no grades yet"

异常情况:

1)如果解析某个成绩信息时,课程名称不在已输入的课程列表中,输出:学号+英文空格+姓名+英文空格+":"+课程名称+英文空格+"does not exist"

2)如果解析某个成绩信息时,输入的成绩数量和课程的考核方式不匹配,输出:学号+英文空格+姓名+英文空格+": access mode mismatch"

以上两种情况如果同时出现,按第一种情况输出结果。

3)如果解析某个课程信息时,输入的课程性质和课程的考核方式不匹配,输出:课程名称+" : course type & access mode mismatch"

4)格式错误以及其他信息异常如成绩超出范围等,均按格式错误处理,输出"wrong format"

5)若出现重复的课程/成绩信息,只保留第一个课程信息,忽略后面输入的。

信息约束:

1)成绩平均分只取整数部分,小数部分丢弃

参考类图:


image.png

输入样例1:

仅有课程。例如:

java 必修 考试
数据结构 选修 考试
形式与政治 选修 考察
end
 

输出样例1:

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

java has no grades yet
数据结构 has no grades yet
形式与政治 has no grades yet
 

输入样例2:

单门考试课程 单个学生。例如:

java 必修 考试
20201103 张三 java 20 40
end
 

输出样例2:

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

20201103 张三 34
java 20 40 34
202011 34
 

输入样例3:

单门考察课程 单个学生。例如:

java 选修 考察
20201103 张三 java 40
end
 

输出样例3:

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

20201103 张三 40
java 40 40
202011 40
 

输入样例4:

考试课程 单个学生 不匹配的考核方式。例如:

java 必修 考试
20201103 张三 java 20
end
 

输出样例4:

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

20201103 张三 : access mode mismatch
20201103 张三 did not take any exams
java has no grades yet
202011 has no grades yet
 

输入样例5:

单门课程,单个学生,课程类型与考核类型不匹配。例如:

java 必修 考察
20201103 张三 java 40
end
 

输出样例5:

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

java : course type & access mode mismatch
java does not exist
20201103 张三 did not take any exams
202011 has no grades yet
 

输入样例6:

单门课程,多个学生。例如:

java 选修 考察
20201103 李四 java 60
20201104 王五 java 60
20201101 张三 java 40
end
 

输出样例6:

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

20201101 张三 40
20201103 李四 60
20201104 王五 60
java 53 53
202011 53
 

输入样例7:

单门课程,单个学生,课程类型与考核类型不匹配。例如:

形式与政治 必修 考试
数据库 选修 考试
java 选修 考察
数据结构 选修 考察
20201103 李四 数据结构 70
20201103 李四 形式与政治 80 90
20201103 李四 java 60
20201103 李四 数据库 70 78
end
 

输出样例7:

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

20201103 李四 73
java 60 60
数据结构 70 70
数据库 70 78 75
形式与政治 80 90 87
202011 73
 

输入样例8:

单门课程,单个学生,成绩越界。例如:

数据结构 选修 考察
20201103 李四 数据结构 101
end
 

输出样例8:

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

wrong format
数据结构 has no grades yet
 

输入样例9:

多门课程,多个学生,多个成绩。例如:

形式与政治 必修 考试
数据库 选修 考试
java 选修 考察
数据结构 选修 考察
20201205 李四 数据结构 70
20201103 李四 形式与政治 80 90
20201102 王五 java 60
20201211 张三 数据库 70 78
end
 

输出样例9:

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

20201102 王五 60
20201103 李四 87
20201205 李四 70
20201211 张三 75
java 60 60
数据结构 70 70
数据库 70 78 75
形式与政治 80 90 87
202011 73
202012 72

          这题代码如下

  1 import java.util.ArrayList;
  2 import java.util.Scanner;
  3 import java.util.Collections;
  4 import java.util.Comparator;
  5 import java.text.Collator;
  6 import java.util.Locale;
  7 public class Main {
  8     public static void main(String[] args) {
  9       Scanner input = new Scanner(System.in);
 10       ChooseClass chooseClass = new ChooseClass();
 11       ClassList classList = new ClassList();
 12       String[] s;
 13       String str = "^[0-9]{1,8}$";
 14       String str1 = "^([0-9][0-9]{0,1}|100)$";
 15       while(true){
 16           String s1 = input.nextLine();
 17           s = s1.split(" ");
 18           if(s1.equals("end")){
 19               break;
 20           }
 21           int n = s.length;
 22             if(n == 2){
 23               if(s[1].equals("必修")&&s[0].length()<=10){
 24                   Lesson lesson =new Lesson(s[0],s[1]);
 25                   chooseClass.addLesson(lesson);
 26               }else {
 27                   System.out.println("wrong format");
 28               }
 29           } else if (n == 3) {
 30               if((s[0].matches(str) && s[1].length() <= 10)){
 31                   if(chooseClass.searchLesson(s[2])!=null) {
 32                       System.out.println(s[0] + " " + s[1] + " : access mode mismatch");
 33                   }else {
 34                       System.out.println(s[2] + " does not exist");
 35                   }
 36               }else {
 37                   Lesson lesson = new Lesson(s[0], s[1], s[2]);
 38                   if (s[0].length() <= 10) {
 39                       if (s[1].equals("必修")) {
 40                           if (s[2].equals("考试")) {
 41                               chooseClass.addLesson(lesson);
 42                           } else if (s[2].equals("考察")) {
 43                               System.out.println(lesson.name + " : course type & access mode mismatch");
 44                           } else {
 45                               System.out.println("wrong format");
 46                           }
 47                       } else if (s[1].equals("选修")) {
 48                           if (s[2].equals("考试") || s[2].equals("考察")) {
 49                               chooseClass.addLesson(lesson);
 50                           } else {
 51                               System.out.println("wrong format");
 52                           }
 53                       } else {
 54                           System.out.println("wrong format");
 55                       }
 56                   } else {
 57                       System.out.println("wrong format");
 58                   }
 59               }
 60           } else if (n == 4) {
 61            if(s[3].matches(str1)) {
 62                   int testGrade = Integer.valueOf(s[3]);
 63                   if (s[0].matches(str) && s[1].length() <= 10) {
 64                       String classNUmber = s[0].substring(0, 6);
 65                       Student student = new Student(s[1], s[0]);
 66                       Class cl1 = new Class(classNUmber);
 67                       if (classList.searchClass(classNUmber) != null) {
 68                           cl1 = classList.searchClass(classNUmber);
 69                           if (cl1.searchStudent(s[0]) != null) {
 70                               student = cl1.searchStudent(s[0]);
 71                           } else {
 72                               cl1.addStudent(student);
 73                           }
 74                       } else {
 75                           cl1.addStudent(student);
 76                           classList.addClass(cl1);
 77                       }
 78                       Lesson lesson1 = chooseClass.searchLesson(s[2]);
 79                       if (lesson1 == null) {
 80                           System.out.println(s[2] + " does not exist");
 81                       } else {
 82                           if (student.searchLesson(s[2]) == null) {
 83                               if (lesson1.TestType.equals("考察")) {
 84                                   student.addLesson(lesson1);
 85                                   lesson1.testFlag++;
 86                                   lesson1.flag++;
 87                                   lesson1.testGrade += testGrade;
 88                                   student.sum += testGrade;
 89                                   lesson1.finalGrade += testGrade;
 90                                   student.flag++;
 91                               } else {
 92                                   System.out.println(student.number + " " + student.name + " : access mode mismatch");
 93                               }
 94                           }
 95                       }
 96                   } else {
 97                       System.out.println("wrong format");
 98                   }
 99               }else {
100                   System.out.println("wrong format");
101               }
102           } else if (n == 5) {
103               if (s[3].matches(str1)&&s[4].matches(str1)) {
104                   int timeGrade = Integer.valueOf(s[3]);
105                   int testGrade = Integer.valueOf(s[4]);
106                   if (s[0].matches(str) && s[1].length() <= 10) {
107                       String classNUmber = s[0].substring(0, 6);
108                       Student student = new Student(s[1], s[0]);
109                       Class cl1 = new Class(classNUmber);
110                       if (classList.searchClass(classNUmber) != null) {
111                           cl1 = classList.searchClass(classNUmber);
112                           if (cl1.searchStudent(s[0]) != null) {
113                               student = cl1.searchStudent(s[0]);
114                           } else {
115                               cl1.addStudent(student);
116                           }
117                       } else {
118                           cl1.addStudent(student);
119                           classList.addClass(cl1);
120                       }
121                       Lesson lesson1 = chooseClass.searchLesson(s[2]);
122                       if (lesson1 == null) {
123                           System.out.println(s[2] + " does not exist");
124                       } else {
125                           if (student.searchLesson(s[2]) == null) {
126                               if (lesson1.TestType.equals("考试")) {
127                                   student.addLesson(lesson1);
128                                   lesson1.testFlag++;
129                                   lesson1.timeFlag++;
130                                   lesson1.flag++;
131                                   lesson1.timeGrade += timeGrade;
132                                   lesson1.testGrade += testGrade;
133                                   int grade = Grade.doGrade(lesson1, timeGrade, testGrade);
134                                   student.sum += grade;
135                                   lesson1.finalGrade += grade;
136                                   student.flag++;
137                               } else {
138                                   System.out.println(student.number + " " + student.name + " : access mode mismatch");
139                               }
140                           }
141                       }
142                   } else {
143                       System.out.println("wrong format");
144                   }
145               }else {
146                   System.out.println("wrong format");
147               }
148           }else if(n>5){
149                   if((s[0].matches(str) && s[1].length() <= 10)){
150                       if(chooseClass.searchLesson(s[2])!=null) {
151                           System.out.println(s[0] + " " + s[1] + " : access mode mismatch");
152                       }else {
153                           System.out.println(s[2] + " does not exist");
154                       }
155               }else {
156                   System.out.println("wrong format");
157               }
158           }else{
159               System.out.println("wrong format");
160           }
161       }
162       classList.sort();
163       for(Class classList1 : classList.cl){
164           classList1.sort();
165           for(Student student : classList1.students) {
166               if (student.flag == 0) {
167                   System.out.println(student.number+" "+student.name +" "+"did not take any exams");
168               }else {
169                   student.finalGrade = student.sum / student.flag;
170                   classList1.grade += student.finalGrade;
171                   classList1.flag++;
172                   System.out.println(student.number+" "+student.name+" "+student.finalGrade);
173               }
174           }
175       }
176       chooseClass.sort();
177       for(Lesson lesson : chooseClass.lessons){
178           if(lesson.flag==0){
179               System.out.println(lesson.name+" has no grades yet");
180           }else {
181               if(lesson.timeGrade!=0){
182                   System.out.println(lesson.name+" "+lesson.timeGrade/ lesson.timeFlag+" "+lesson.testGrade/lesson.testFlag+" "+lesson.finalGrade/lesson.flag);
183               }else {
184                   System.out.println(lesson.name+" "+lesson.testGrade/lesson.testFlag+" "+lesson.finalGrade/lesson.flag);
185               }
186           }
187       }
188       for(Class classList1 : classList.cl){
189           if(classList1.flag==0){
190                 System.out.println(classList1.number+" has no grades yet");
191           }else {
192               classList1.finalGrade = classList1.grade/classList1.flag;
193               System.out.println(classList1.number+" " +classList1.finalGrade);
194           }
195       }
196     }
197  }
198  class ClassList {
199     ArrayList<Class> cl =new ArrayList<>();
200     public void addClass(Class cl2){
201        if(searchClass(cl2.number) != null){
202 
203        }else{
204            cl.add(cl2);
205        }
206     }
207     public Class searchClass(String number){
208         for(Class cl1 : cl){
209             if (cl1.number.equals(number)){
210                 return cl1;
211             }
212         }
213         return null;
214     }
215     public void sort(){
216         Collections.sort(cl,new Comparator<Object>(){
217             @Override
218             public int compare(Object o1, Object o2) {
219                 return ((Class) o1).classNumber - ((Class) o2).classNumber;
220             }
221         });
222     }
223 }
224  class Class {
225        String number = "";
226        int grade ;
227        int finalGrade;
228        int flag = 0;
229        int classNumber = 0;
230        ArrayList<Student> students = new ArrayList<>();
231        Class(String number){
232            this.number = number;
233            this.classNumber = Integer.valueOf(number);
234        }
235        public void addStudent(Student student1){
236            if(searchStudent(student1.number)!=null){
237 
238            }else {
239                students.add(student1);
240            }
241        }
242        public Student searchStudent(String number){
243            for(Student student:students) {
244                if (student.number.equals(number)) {
245                    return student;
246                }
247            }
248            return null;
249        }
250        public void sort(){
251            Collections.sort(students,new Comparator<Object>(){
252                @Override
253                public int compare(Object o1, Object o2) {
254                    return ((Student) o1).number1 - ((Student) o2).number1;
255                }
256            });
257        }
258 }
259  class Grade {
260      public static int doGrade(Lesson lesson, int timeGrade, int testGrade){
261           int grade = 0;
262           if(lesson.TestType.equals("考试")){
263                grade = (int) (timeGrade*0.3 + testGrade*0.7);
264                return  grade;
265           }else if(lesson.TestType.equals("考察")){
266                grade = testGrade;
267                return grade;
268           }else {
269                return  grade;
270           }
271      }
272 }
273  class ChooseClass {
274     ArrayList<Lesson> lessons = new ArrayList<>();
275     public void addLesson(Lesson lesson1){
276        if(searchLesson(lesson1.name)!=null){
277 
278        }else {
279            lessons.add(lesson1);
280        }
281     }
282 
283     public Lesson searchLesson(String name){
284         for(Lesson lesson : lessons){
285             if(lesson.getName().equals(name)){
286                 return lesson;
287             }
288         }
289         return null;
290     }
291     public void sort(){
292         Comparator comparator = Collator.getInstance(Locale.CHINA);
293         Collections.sort(lessons, (e1, e2) -> {
294             return comparator.compare(e1.getName(), e2.getName());
295         });
296     }
297 }
298  
299  class Student {
300     String name=  "";
301     String number = "";
302     int number1 = 0;
303     int flag = 0;
304     int finalGrade;
305     int sum;
306     Student(String name,String number,int grade){
307         this.name = name;
308         this.number = number;
309         this.finalGrade =  grade;
310     }
311     Student(String name){
312         this.name = name;
313     }
314     Student(String name,String number){
315         this.name = name;
316         this.number = number;
317         this.number1 = Integer.valueOf(number.substring(6,8));
318     }
319       ArrayList<Lesson> lessons = new ArrayList<>();
320     public void addLesson(Lesson lesson1){
321         if(searchLesson(lesson1.name)!=null){
322 
323         }else {
324             lessons.add(lesson1);
325         }
326     }
327 
328     public Lesson searchLesson(String name){
329         for(Lesson lesson : lessons){
330             if(lesson.getName().equals(name)){
331                 return lesson;
332             }
333         }
334         return null;
335     }
336 }
337 class Lesson {
338     String name = "";
339     String ClassType = "";
340     String TestType = "";
341     int timeGrade = 0;
342     int testGrade = 0;
343     int finalGrade =0;
344     int timeFlag = 0;
345     int testFlag = 0;
346     int flag = 0;
347     public String getName() {
348         return name;
349     }
350     Lesson(String name, String classType , String testType){
351         this.name = name;
352         this.ClassType = classType;
353         this.TestType = testType;
354     }
355     Lesson(String name, String classType){
356         this.name = name;
357         this.ClassType = classType;
358         this.TestType = "考试";
359     }
360 }

   这里我的思路和前面点菜题的思路差不多,都是一个循环对输入的数据进行处理,不过对于这题与点菜的差别在于,对于数据输入时不能直接输出结果他得先储存所有的输入信息在最后进行输出。

 

7-3 课程成绩统计程序-2 分数 60 作者 蔡轲 单位 南昌航空大学

课程成绩统计程序-2在第一次的基础上增加了实验课,以下加粗字体显示为本次新增的内容。

某高校课程从性质上分为:必修课、选修课、实验课,从考核方式上分为:考试、考察、实验。

考试的总成绩由平时成绩、期末成绩分别乘以权重值得出,比如平时成绩权重0.3,期末成绩权重0.7,总成绩=平时成绩*0.3+期末成绩*0.7。

考察的总成绩直接等于期末成绩

实验的总成绩等于课程每次实验成绩的平均分

必修课的考核方式必须为考试,选修课可以选择考试、考察任一考核方式。实验课的成绩必须为实验。

1、输入:

包括课程、课程成绩两类信息。

课程信息包括:课程名称、课程性质、考核方式(可选,如果性质是必修课,考核方式可以没有)三个数据项。

课程信息格式:课程名称+英文空格+课程性质+英文空格+考核方式

课程性质输入项:必修、选修、实验

考核方式输入选项:考试、考察、实验

考试/考查课程成绩信息包括:学号、姓名、课程名称、平时成绩(可选)、期末成绩

考试/考查课程信息格式:学号+英文空格+姓名+英文空格+课程名称+英文空格+平时成绩+英文空格+期末成绩

实验课程成绩信息包括:学号、姓名、课程名称、实验次数、每次成绩

实验次数至少4次,不超过9次

实验课程信息格式:学号+英文空格+姓名+英文空格+课程名称+英文空格+实验次数+英文空格+第一次实验成绩+...+英文空格+最后一次实验成绩

以上信息的相关约束:

1)平时成绩和期末成绩的权重默认为0.3、0.7

2)成绩是整数,不包含小数部分,成绩的取值范围是【0,100】

3)学号由8位数字组成

4)姓名不超过10个字符

5)课程名称不超过10个字符

6)不特别输入班级信息,班级号是学号的前6位。

2、输出:

输出包含三个部分,包括学生所有课程总成绩的平均分、单门课程成绩平均分、单门课程总成绩平均分、班级所有课程总成绩平均分。

为避免误差,平均分的计算方法为累加所有符合条件的单个成绩,最后除以总数。

1)学生课程总成绩平均分按学号由低到高排序输出

格式:学号+英文空格+姓名+英文空格+总成绩平均分

如果某个学生没有任何成绩信息,输出:学号+英文空格+姓名+英文空格+"did not take any exams"

2)单门课程成绩平均分分为三个分值:平时成绩平均分(可选)、期末考试平均分、总成绩平均分,按课程名称的字符顺序输出

考试/考察课程成绩格式:课程名称+英文空格+平时成绩平均分+英文空格+期末考试平均分+英文空格+总成绩平均分

实验课成绩格式:课程名称+英文空格+总成绩平均分

如果某门课程没有任何成绩信息,输出:课程名称+英文空格+"has no grades yet"

3)班级所有课程总成绩平均分按班级由低到高排序输出

格式:班级号+英文空格+总成绩平均分

如果某个班级没有任何成绩信息,输出:班级名称+英文空格+ "has no grades yet"

异常情况:

1)如果解析某个成绩信息时,课程名称不在已输入的课程列表中,输出:学号+英文空格+姓名+英文空格+":"+课程名称+英文空格+"does not exist"

2)如果解析某个成绩信息时,输入的成绩数量和课程的考核方式不匹配,输出:学号+英文空格+姓名+英文空格+": access mode mismatch"

以上两种情况如果同时出现,按第一种情况输出结果。

3)如果解析某个课程信息时,输入的课程性质和课程的考核方式不匹配,输出:课程名称+" : course type & access mode mismatch"

4)格式错误以及其他信息异常如成绩超出范围等,均按格式错误处理,输出"wrong format"

5)若出现重复的课程/成绩信息,只保留第一个课程信息,忽略后面输入的。

信息约束:

1)成绩平均分只取整数部分,小数部分丢弃

参考类图(与第一次相同,其余内容自行补充):


e724fa4193aa9ee32e78a68cd96fd6df_22401e04-c501-4b28-bb65-dabe39d374e7.png

 

输入样例1:

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

java 实验 实验
20201103 张三 java 4 70 80 90
end
 

输出样例1:

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

20201103 张三 : access mode mismatch
20201103 张三 did not take any exams
java has no grades yet
202011 has no grades yet
 

输入样例2:

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

java 实验 实验
20201103 张三 java 3 70 80 90
end
 

输出样例2:

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

wrong format
java has no grades yet
 

输入样例3:

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

java 必修 实验
20201103 张三 java 3 70 80 90 100
end
 

输出样例3:

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

java : course type & access mode mismatch
wrong format
 

输入样例4:

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

java 必修 实验
20201103 张三 java 4 70 80 90 105
end
 

输出样例4:

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

java : course type & access mode mismatch
wrong format
 

 

输入样例5:

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

java 选修 考察
C语言 选修 考察
java实验 实验 实验
编译原理 必修 考试
20201101 王五 C语言 76
20201216 李四 C语言 78
20201307 张少军 编译原理 82 84
20201103 张三 java实验 4 70 80 90 100
20201118 郑觉先 java 80
20201328 刘和宇 java 77
20201220 朱重九 java实验 4 60 60 80 80
20201132 王萍 C语言 40
20201302 李梦涵 C语言 68
20201325 崔瑾 编译原理 80 84
20201213 黄红 java 82
20201209 赵仙芝 java 76
end
 

输出样例5:

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

20201101 王五 76
20201103 张三 85
20201118 郑觉先 80
20201132 王萍 40
20201209 赵仙芝 76
20201213 黄红 82
20201216 李四 78
20201220 朱重九 70
20201302 李梦涵 68
20201307 张少军 83
20201325 崔瑾 82
20201328 刘和宇 77
C语言 65 65
java 78 78
java实验 77
编译原理 81 84 82
202011 70
202012 76
202013 77

这题代码如下
  1 import java.util.ArrayList;
  2 import java.util.Scanner;
  3 import java.util.Collections;
  4 import java.util.Comparator;
  5 import java.text.Collator;
  6 import java.util.Locale;
  7 public class Main {
  8     public static void main(String[] args) {
  9       Scanner input = new Scanner(System.in);
 10       ChooseClass chooseClass = new ChooseClass();
 11       ClassList classList = new ClassList();
 12       String str = "^[0-9]{1,8}$";
 13       String str1 = "^([0-9][0-9]{0,1}|100)$";
 14         String[] s;
 15       while(true){
 16           String s1 = input.nextLine();
 17           s = s1.split(" ");
 18           if(s1.equals("end")){
 19               break;
 20           }
 21           int n = s.length;
 22           if(n == 2){
 23               if(s[1].equals("必修")&&s[0].length()<=10){
 24                   Lesson lesson =new Lesson(s[0],s[1]);
 25                   chooseClass.addLesson(lesson);
 26               }else {
 27                   System.out.println("wrong format");
 28               }
 29           } else if (n == 3) {
 30               if((s[0].matches(str) && s[1].length() <= 10)){
 31                   if(chooseClass.searchLesson(s[2])!=null) {
 32                       System.out.println(s[0] + " " + s[1] + " : access mode mismatch");
 33                   }else {
 34                       System.out.println(s[2] + " does not exist");
 35                   }
 36               }else {
 37                   Lesson lesson = new Lesson(s[0], s[1], s[2]);
 38                   if (s[0].length() <= 10) {
 39                       if (s[1].equals("必修")) {
 40                           if (s[2].equals("考试")) {
 41                               chooseClass.addLesson(lesson);
 42                           } else if (s[2].equals("考察")||s[2].equals("实验")) {
 43                               System.out.println(lesson.name + " : course type & access mode mismatch");
 44                           } else {
 45                               System.out.println("wrong format");
 46                           }
 47                       } else if (s[1].equals("选修")) {
 48                           if (s[2].equals("考试") || s[2].equals("考察")) {
 49                               chooseClass.addLesson(lesson);
 50                           } else {
 51                               System.out.println("wrong format");
 52                           }
 53                       }else  if(s[1].equals("实验")){
 54                           if(s[2].equals("实验")){
 55                               chooseClass.addLesson(lesson);
 56                           }else if(s[2].equals("考试") || s[2].equals("考察")){
 57                               System.out.println(lesson.name + " : course type & access mode mismatch");
 58                           }else {
 59                               System.out.println("wrong format");
 60                           }
 61                       } else {
 62                           System.out.println("wrong format");
 63                       }
 64                   } else {
 65                       System.out.println("wrong format");
 66                   }
 67               }
 68           } else if (n == 4) {
 69               if(s[3].matches(str1)) {
 70                   int testGrade = Integer.valueOf(s[3]);
 71                   if (s[0].matches(str) && s[1].length() <= 10) {
 72                       String classNUmber = s[0].substring(0, 6);
 73                       Student student = new Student(s[1], s[0]);
 74                       Class cl1 = new Class(classNUmber);
 75                       if (classList.searchClass(classNUmber) != null) {
 76                           cl1 = classList.searchClass(classNUmber);
 77                           if (cl1.searchStudent(s[0]) != null) {
 78                               student = cl1.searchStudent(s[0]);
 79                           } else {
 80                               cl1.addStudent(student);
 81                           }
 82                       } else {
 83                           cl1.addStudent(student);
 84                           classList.addClass(cl1);
 85                       }
 86                       Lesson lesson1 = chooseClass.searchLesson(s[2]);
 87                       if (lesson1 == null) {
 88                           System.out.println(s[2] + " does not exist");
 89                       } else {
 90                           if (student.searchLesson(s[2]) == null) {
 91                               if (lesson1.TestType.equals("考察")) {
 92                                   student.addLesson(lesson1);
 93                                   lesson1.testFlag++;
 94                                   lesson1.flag++;
 95                                   lesson1.testGrade += testGrade;
 96                                   student.sum += testGrade;
 97                                   lesson1.finalGrade += testGrade;
 98                                   student.flag++;
 99                               } else {
100                                   System.out.println(student.number + " " + student.name + " : access mode mismatch");
101                               }
102                           }
103                       }
104                   } else {
105                       System.out.println("wrong format");
106                   }
107               }else {
108                   System.out.println("wrong format");
109               }
110           } else if (n == 5) {
111               if (s[3].matches(str1)&&s[4].matches(str1)) {
112                   int timeGrade = Integer.valueOf(s[3]);
113                   int testGrade = Integer.valueOf(s[4]);
114                   if (s[0].matches(str) && s[1].length() <= 10) {
115                       String classNUmber = s[0].substring(0, 6);
116                       Student student = new Student(s[1], s[0]);
117                       Class cl1 = new Class(classNUmber);
118                       if (classList.searchClass(classNUmber) != null) {
119                           cl1 = classList.searchClass(classNUmber);
120                           if (cl1.searchStudent(s[0]) != null) {
121                               student = cl1.searchStudent(s[0]);
122                           } else {
123                               cl1.addStudent(student);
124                           }
125                       } else {
126                           cl1.addStudent(student);
127                           classList.addClass(cl1);
128                       }
129                       Lesson lesson1 = chooseClass.searchLesson(s[2]);
130                       if (lesson1 == null) {
131                           System.out.println(s[2] + " does not exist");
132                       } else {
133                           if (student.searchLesson(s[2]) == null) {
134                               if (lesson1.TestType.equals("考试")) {
135                                   student.addLesson(lesson1);
136                                   lesson1.testFlag++;
137                                   lesson1.timeFlag++;
138                                   lesson1.flag++;
139                                   lesson1.timeGrade += timeGrade;
140                                   lesson1.testGrade += testGrade;
141                                   int grade = Grade.doGrade(lesson1, timeGrade, testGrade);
142                                   student.sum += grade;
143                                   lesson1.finalGrade += grade;
144                                   student.flag++;
145                               } else {
146                                   System.out.println(student.number + " " + student.name + " : access mode mismatch");
147                               }
148                           }
149                       }
150                   } else {
151                       System.out.println("wrong format");
152                   }
153               }else {
154                   System.out.println("wrong format");
155               }
156           }else if(n>5){
157                   if((s[0].matches(str) && s[1].length() <= 10)){
158 
159                       int h = Integer.valueOf(s[3]);
160                       int countFlag = 0;
161                       if(h>=4&&h<=9) {
162                         for(int i = h;i< s.length;i++){
163                             if(!s[i].matches(str1)){
164                                 countFlag++;
165                             }
166                         }
167                         if(countFlag==0) {
168                             String classNUmber = s[0].substring(0, 6);
169                             Student student = new Student(s[1], s[0]);
170                             Class cl1 = new Class(classNUmber);
171                             if (classList.searchClass(classNUmber) != null) {
172                                 cl1 = classList.searchClass(classNUmber);
173                                 if (cl1.searchStudent(s[0]) != null) {
174                                     student = cl1.searchStudent(s[0]);
175                                 } else {
176                                     cl1.addStudent(student);
177                                 }
178                             } else {
179                                 cl1.addStudent(student);
180                                 classList.addClass(cl1);
181                             }
182                             Lesson lesson1 = chooseClass.searchLesson(s[2]);
183                             if (chooseClass.searchLesson(s[2]) != null) {
184                                 if((s.length-h)==4) {
185                                     if(student.searchLesson(s[2])==null){
186                                         student.addLesson(lesson1);
187                                         lesson1.flag++;
188                                         lesson1.experimentFlag++;
189                                         int grade = 0;
190                                         for(int i = 4;i<s.length;i++){
191                                             grade += Integer.valueOf(s[i]);
192                                         }
193                                         student.sum += grade;
194                                         lesson1.finalGrade += grade/h;
195                                         student.flag+=h;
196                                     }
197                                 }else {
198                                     System.out.println(s[0] + " " + s[1] + " : access mode mismatch");
199                                 }
200                             } else {
201                                 System.out.println(s[2] + " does not exist");
202                             }
203                         }else {
204                             System.out.println("wrong format");
205                         }
206                       }else {
207                           System.out.println("wrong format");
208                       }
209               }else {
210                   System.out.println("wrong format");
211               }
212           }else{
213               System.out.println("wrong format");
214           }
215       }
216       classList.sort();
217       for(Class classList1 : classList.cl){
218           classList1.sort();
219           for(Student student : classList1.students) {
220               if (student.flag == 0) {
221                   System.out.println(student.number+" "+student.name +" "+"did not take any exams");
222               }else {
223                   student.finalGrade = student.sum / student.flag;
224                   classList1.grade += student.finalGrade;
225                   classList1.flag++;
226                   System.out.println(student.number+" "+student.name+" "+student.finalGrade);
227               }
228           }
229       }
230       chooseClass.sort();
231       for(Lesson lesson : chooseClass.lessons){
232           if(lesson.flag==0){
233               System.out.println(lesson.name+" has no grades yet");
234           }else {
235               if(lesson.timeGrade!=0){
236                   System.out.println(lesson.name+" "+lesson.timeGrade/ lesson.timeFlag+" "+lesson.testGrade/lesson.testFlag+" "+lesson.finalGrade/lesson.flag);
237               }else {
238                   if(lesson.experimentFlag == 0) {
239                       System.out.println(lesson.name + " " + lesson.testGrade / lesson.testFlag + " " + lesson.finalGrade / lesson.flag);
240                   }else {
241                     System.out.println(lesson.name+" "+lesson.finalGrade / lesson.flag);
242                   }
243               }
244           }
245       }
246       for(Class classList1 : classList.cl){
247           if(classList1.flag==0){
248                 System.out.println(classList1.number+" has no grades yet");
249           }else {
250               classList1.finalGrade = classList1.grade/classList1.flag;
251               System.out.println(classList1.number+" " +classList1.finalGrade);
252           }
253       }
254     }
255 }
256  class Student {
257     String name=  "";
258     String number = "";
259     int number1 = 0;
260     int flag = 0;
261     int finalGrade;
262     int sum;
263     Student(String name,String number,int grade){
264         this.name = name;
265         this.number = number;
266         this.finalGrade =  grade;
267     }
268     Student(String name){
269         this.name = name;
270     }
271     Student(String name,String number){
272         this.name = name;
273         this.number = number;
274         this.number1 = Integer.valueOf(number.substring(6,8));
275     }
276     ArrayList<Lesson> lessons = new ArrayList<>();
277     public void addLesson(Lesson lesson1){
278         if(searchLesson(lesson1.name)!=null){
279 
280         }else {
281             lessons.add(lesson1);
282         }
283     }
284 
285     public Lesson searchLesson(String name){
286         for(Lesson lesson : lessons){
287             if(lesson.getName().equals(name)){
288                 return lesson;
289             }
290         }
291         return null;
292     }
293 }
294 class Lesson {
295     String name = "";
296     String ClassType = "";
297     String TestType = "";
298     int timeGrade = 0;
299     int testGrade = 0;
300     int finalGrade =0;
301     int timeFlag = 0;
302     int testFlag = 0;
303     int flag = 0;
304     int experimentFlag = 0;
305     public String getName() {
306         return name;
307     }
308     Lesson(String name, String classType , String testType){
309         this.name = name;
310         this.ClassType = classType;
311         this.TestType = testType;
312     }
313     Lesson(String name, String classType){
314         this.name = name;
315         this.ClassType = classType;
316         this.TestType = "考试";
317     }
318 }
319  class Grade {
320      public static int doGrade(Lesson lesson, int timeGrade, int testGrade){
321           int grade = 0;
322           if(lesson.TestType.equals("考试")){
323                grade = (int) (timeGrade*0.3 + testGrade*0.7);
324                return  grade;
325           }else if(lesson.TestType.equals("考察")){
326                grade = testGrade;
327                return grade;
328           }else {
329                return  grade;
330           }
331      }
332 }
333  class ClassList {
334     ArrayList<Class> cl =new ArrayList<>();
335     public void addClass(Class cl2){
336        if(searchClass(cl2.number) != null){
337 
338        }else{
339            cl.add(cl2);
340        }
341     }
342     public Class searchClass(String number){
343         for(Class cl1 : cl){
344             if (cl1.number.equals(number)){
345                 return cl1;
346             }
347         }
348         return null;
349     }
350     public void sort(){
351         Collections.sort(cl,new Comparator<Object>(){
352             @Override
353             public int compare(Object o1, Object o2) {
354                 return ((Class) o1).classNumber - ((Class) o2).classNumber;
355             }
356         });
357     }
358 }
359 class Class {
360        String number = "";
361        int grade ;
362        int finalGrade;
363        int flag = 0;
364        int classNumber = 0;
365        ArrayList<Student> students = new ArrayList<>();
366        Class(String number){
367            this.number = number;
368            this.classNumber = Integer.valueOf(number);
369        }
370        public void addStudent(Student student1){
371            if(searchStudent(student1.number)!=null){
372 
373            }else {
374                students.add(student1);
375            }
376        }
377        public Student searchStudent(String number){
378            for(Student student:students) {
379                if (student.number.equals(number)) {
380                    return student;
381                }
382            }
383            return null;
384        }
385        public void sort(){
386            Collections.sort(students,new Comparator<Object>(){
387                @Override
388                public int compare(Object o1, Object o2) {
389                    return ((Student) o1).number1 - ((Student) o2).number1;
390                }
391            });
392        }
393 }
394  class ChooseClass {
395     ArrayList<Lesson> lessons = new ArrayList<>();
396     public void addLesson(Lesson lesson1){
397        if(searchLesson(lesson1.name)!=null){
398 
399        }else {
400            lessons.add(lesson1);
401        }
402     }
403 
404     public Lesson searchLesson(String name){
405         for(Lesson lesson : lessons){
406             if(lesson.getName().equals(name)){
407                 return lesson;
408             }
409         }
410         return null;
411     }
412     public void sort(){
413         Comparator comparator = Collator.getInstance(Locale.CHINA);
414         Collections.sort(lessons, (e1, e2) -> {
415             return comparator.compare(e1.getName(), e2.getName());
416         });
417     }
418 }

这题主要是添加了第三个课程,实验课,我们要输入对应的实验的成绩来计算,我们只需要在课程类里添加个标识就行

(3)踩坑心得:

      对于第一次主要是对于错误信息的处理有错

                       和别人的代码进行对比发现别人使用的是正则表达式进行对信息的判断,我则是直接判断

     第二次主要是对于实验课的计算有问题

            

           在计算时应当好好检查几次,不然极易导致小错误

(4)改进建议:
我应该对于判断输入数据时使用正则表达式既可以使我的代码既简单又复用性高,对于数据的计算时应当注意算法的问题
(5)总结:

                       这阶段,我们学会了hashmap,等map和set等类的用法,但是我对正则表达式的使用还是过于少,在后面的学习中要对正则表达式更加了解及使用,对于PTA作业应当追求满分,不能有几个测试点没过就放弃。

第二部分 课程评价

          我觉得首先对于PTA的题目应当更加多样性,考察的方向应该多元化,有些题目的做法大差不差,应该优化一下。还有对于教学方法应该给出更多的教学时间,对教学内容更加了解,这样才适合我们去实践。

标签:总结,阶段性,java,String,int,PTA,空格,课程,name
From: https://www.cnblogs.com/rccxs/p/17510213.html

相关文章

  • 每日总结2023年6月27日
    今日学习:1.关于数据的知识点回顾复习;计算机组成原理————了解CPU组成,了解流水线概念以及计算流水线周期以及流水线吞吐量(软考准备)2.学习大数据基本概念,大数据特点(4V:大量,高速,多样,价值);Hadoop基本概念,发展历史以及组成结构,Hadoop一共有三代,第一代Hadoop是由MapReduce负责计算和......
  • oop题目集7~11的总结性Blog
    目录一、前言二、设计与分析:一、前言4~6的训练集难度较上一次提升很多,训练了很多java中独有的提供好的方法,如hashset,数组的sort等方法,实现了代码运行时间的优化,和内存的占用减少,学会了代码的封装,和使用类间关系,同时了解并使用了正则表达式,了解Scanner类中nextLine()等方法、Str......
  • PTA第三阶段题目集总结
    一.  前言PTA第三阶段的题目集包括了题集7891011。第7次题集是最后一次的菜单类,是对前一段菜单类的题目的总结,个人认为对于我来说有一定难度。第8次题集是课程成绩统计程序的第一次作业,要求输入课程信息与学生信息,最后再进行总结计算课程成绩以及学生和班级成绩后输出。......
  • 面向对象程序设计题目集总结blog3
    一、前言本次是第三次对面向对象程序设计题目集的总结分析博客。 关于知识点本次的题目集所体现的知识点重点考虑设计问题,许多题目不提供类图,或者只提供一个参考框架(只有类和类之间的关系),题目的代码量也较于前几次提升了不少。题目集七注重类的设计,通过三道设......
  • pta第三阶段题目集
    (1)前言pta第三阶段作业中,主要包含了如下的主要内容:1.全程贯穿了课程设计的程序,每一次都是上一次的迭代和修改,难度较大,中间涉及到先是类与类之间的多态和继承关系,后面的修改中,转变为了组合的关系,我认为难度较高,相较于之前的菜单类设计还是简单了一些。2.有一道 统计Java程序中关......
  • Linux(Ubuntu) 常用命令的总结
    Linux(Ubuntu)常用命令的总结总结工作中用到的ubuntu命令,和添加一些常见的Linux的命令;1.文件操作&常见命令操作前置补充:Linux终端提示符&&命令语法Centos[root@oldboy_python~]##[用户名@主机机器名路径]提示符#用户名root#主机名oldboy_python#......
  • OO题目集7-11总结
    一、前言本次题目集横跨时间较长,也是本课程的最后一次总结了,回首看第一次OO总结,真的感觉今时不同往日了,不仅仅是在能力上的提升,在各方各面上无疑都觉得已经成长了许多(变成了puls版小菜鸡)。题目集七本次题目集是菜单3的与菜单4不同迭代分支,是对于菜单3的另一个迭代方向,只要考察......
  • csgo服务端运维总结
    简述通过LinuxGameServerManagers来管理运行。安装csgo服务端请参考:根据lgsm官网指引进行安装注意,过程中如果因为网络原因下载较慢不要急,超时后会选取备用线路网速就正常了,如果失败了就重新来过,下载过的就不会重新下载。大致流程是获取到linuxgsm.sh,然后bashlinuxgsm.sh......
  • Java学习3——第七至十 一次题目集以及第三阶段学习的分析与总结
    一.前言   本次Blog是对java学习中第三阶段的一个总结,作为刚学习JAVA不久的小白,以下依旧只是本人作为普通学生,以当前能力和状态所做出的总结和分析,不足之处也欢迎各位大佬的指正! 第七至第十一次题目集,总体题量都比较少,其中较多的也就5道题,其它的就1道。总体难度较第四-六......
  • 知识点总结--6月27日
    JDK提供的编译器是什么?javac.exe标识符的概念是什么?标识符的概念:给类、接口、方法、变量取名字时使用到的字符序列组成部分:大小写字母、数字、_、$、中文例如:注意事项:不能以数字开头 譬如:123name就是不合法的区分大小写但是可以包含关键字和保留字。如:不可以使用void......