BLOG-3

前言:

知识点

第一次作业:练习类的构造方法、方法的调用、参数传递、对象的构造与使用;练习循环结构;练习数据的输入与输出;理解抽象类与子类的关系,代码聚合性的调试。

第二次作业:练习类的构造方法、方法的调用、参数传递、对象的构造与使用;练习循环结构;练习数据的输入与输出;理解抽象类与子类的关系,代码聚合性的调试,HashMap的构造及使用,多态的原理及使用。

第三次作业:练习类的构造方法、方法的调用、参数传递、对象的构造与使用;练习循环结构;练习数据的输入与输出;理解抽象类与子类的关系,代码聚合性的调试,ArrayList的构造及使用,接口的原理及使用,接口的原理及使用。

题量

第一次作业:1题

第二次作业:4题

第三次作业:5题

难度等情况

第一次作业:简单

第二次作业:中等

第三次作业:较难

设计与分析:

第一次作业:

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

分数 100
作者 蔡轲
单位 南昌航空大学

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

考试的总成绩由平时成绩、期末成绩分别乘以权重值得出,比如平时成绩权重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.text.Collator;
  2 import java.util.*;
  3 
  4 public class Main {
  5     public static void main(String[] args) {
  6         ParseInput handle=new ParseInput();
  7         Scanner input = new Scanner(System.in);
  8         String nextLine = input.nextLine();
  9         while (!nextLine.equals("end")){
 10             handle.parseInput(nextLine);//解析用户输入的每一行数据
 11             nextLine = input.nextLine();
 12         }
 13         handle.showStudents();
 14         handle.showCourses();
 15         handle.showClasses();
 16     }
 17 }
 18 class Course implements Comparable<Course>{
 19     private String name;
 20     private String Type;
 21     private String method;
 22     public Course() {}
 23     public String getName() {
 24         return name;
 25     }
 26 
 27     public void setName(String name) {
 28         this.name = name;
 29     }
 30 
 31     public String getType() {
 32         return Type;
 33     }
 34 
 35     public void setType(String type) {
 36         Type = type;
 37     }
 38 
 39     public String getMethod() {
 40         return method;
 41     }
 42 
 43     public void setMethod(String method) {
 44         this.method = method;
 45     }
 46 
 47     public Course(String name, String type, String method) {
 48         this.name = name;
 49         Type = type;
 50         this.method = method;
 51     }
 52 
 53     @Override
 54     public int compareTo(Course o) {
 55         Comparator<Object> compare = Collator.getInstance(java.util.Locale.CHINA);
 56         return compare.compare(name,o.getName());
 57     }
 58 }
 59 class Select{
 60 
 61     private Student student = new Student();
 62     private Course course = new Course();
 63     private Score score;
 64 
 65     public Student getStudent() {
 66         return student;
 67     }
 68 
 69     public void setStudent(Student student) {
 70         this.student = student;
 71     }
 72 
 73     public Course getCourse() {
 74         return course;
 75     }
 76 
 77     public void setCourse(Course course) {
 78         this.course = course;
 79     }
 80 
 81     public Score getScore() {
 82         return score;
 83     }
 84 
 85     public void setScore(Score score) {
 86         this.score = score;
 87     }
 88 
 89     public Select(Student student, Course course, Score score) {
 90         this.student = student;
 91         this.course = course;
 92         this.score = score;
 93     }
 94 }
 95 class  ParseInput{
 96     private List<Student> students = new ArrayList<>();
 97     private List<Course> courses = new ArrayList<>();
 98     private List<Select> selects = new ArrayList<>();
 99     private List<Class> classes = new ArrayList<>();
100     void addStudent(String id,String name){
101         Student student = new Student(id,name);
102         if(selects.size()==0){
103             students.add(student);
104         }
105         else {
106             int flag=0;
107             for(Student student1:students){
108                 if ( student1.getId().equals(id)) {
109                     flag = 1;
110                     break;
111                 }
112             }
113             if(flag==0) students.add(student);
114         }
115     }
116     void addCourse(String name,String Type,String method){
117 
118         if(courses.size()==0){
119             Course course1 = new Course(name,Type,method);
120             courses.add(course1);
121         }
122         else {
123             int flag=0;
124             for(Course course:courses){
125                 if (course.getName().equals(name)) {
126                     flag = 1;
127                     break;
128                 }
129             }
130             if(flag==0) {
131                 Course course1 = new Course(name,Type,method);
132                 courses.add(course1);
133             }
134         }
135     }
136     void addSelect(Student student, Course course, Score score){
137 //        Select select = new Select(student,course,score);
138 //        selects.add(select);
139         if(selects.size()==0){
140             Select select = new Select(student,course,score);
141             selects.add(select);
142         }
143         else {
144             int flag=0;
145             for(Select select:selects){
146                 if (select.getStudent().getId().equals(student.getId())&&select.getCourse().getName().equals(course.getName())) {
147                     flag = 1;
148                     break;
149                 }
150             }
151             if(flag==0) {
152                 Select select = new Select(student,course,score);
153                 selects.add(select);
154             }
155         }
156     }
157     void addClass(String id){
158 
159         if(classes.size()==0){
160             Class aclass = new Class(id);
161             classes.add(aclass);
162         }
163         else {
164             int flag=0;
165             for (Class aclass:classes){
166                 if (aclass.getId().equals(id)) {
167                     flag = 1;
168                     break;
169                 }
170             }
171             if(flag==0){
172                 Class Aclass = new Class(id);
173                 classes.add(Aclass);
174             }
175         }
176     }
177     public void parseInput(String input) {
178         String[] sr = input.split(" ");
179         switch (InputMatching.matchingInput(input)){
180             case 0:
181                 System.out.println("wrong format");
182                 break;
183             case 1:{
184                 if(sr[1].equals("必修")&&sr[2].equals("考察"))
185                     System.out.println(sr[0]+" : course type & access mode mismatch");
186                 else addCourse(sr[0],sr[1],sr[2]);
187                 break;
188             }
189             case 2:{
190 
191                 addClass(sr[0].substring(0,6));
192                 Student student = new Student(sr[0],sr[1]);
193                 addStudent(sr[0],sr[1]);
194                 if(isCourseExist(sr[2])==null){
195                     System.out.println(sr[2]+" does not exist");
196                 }
197                 else {
198                     if(isCourseExist(sr[2]).getMethod().equals("考试")&&sr.length==4
199                         ||isCourseExist(sr[2]).getMethod().equals("考察")&&sr.length==5)
200                     System.out.println(sr[0]+" "+sr[1]+" : access mode mismatch");
201                     else if(sr.length==4){
202                         Score score = new KcScore(Integer.parseInt(sr[3]));
203                         addSelect(student,isCourseExist(sr[2]),score);
204                     }
205                     else if(sr.length==5){
206                         Score score = new KsScore(Integer.parseInt(sr[3]),Integer.parseInt(sr[4]));
207                         addSelect(student,isCourseExist(sr[2]),score);
208                     }
209                 }
210             }
211         }
212     }
213     public Course isCourseExist(String name) {
214         for (Course course : courses) {
215             if (course.getName().equals(name))
216                 return course;
217         }
218         return null;
219     }
220     public void showStudents() {
221         Collections.sort(students);
222         for (Student stu : students) {
223             //从总选课表listChooseCourse中获取该生的选课记录集合
224             ArrayList<Select> stuCourseSelects = getStudentselects(stu.getId());
225             if (stuCourseSelects == null) {
226                 System.out.println(stu.getId() + " " + stu.getName() + " " + "did not take any exams");
227             } else {
228                 System.out.println(stu.getId() + " " + stu.getName() + " "
229                         + getAvgTotalScore(stuCourseSelects));
230             }
231         }
232     }
233     public void showCourses() {
234         Collections.sort(courses);
235         for(Course cou:courses){
236             //从总选课表listChooseCourse中获取该course的选课记录集合
237             ArrayList<Select> couCourseSelection = getCourseselect(cou.getName());
238             if(couCourseSelection==null){
239                 System.out.println(cou.getName()+" has no grades yet");
240             } else {
241                 if(cou.getMethod().equals("考察"))
242                     System.out.println(cou.getName()+" "+getAvgFinalTotalScore(couCourseSelection)+" "
243                     +getAvgTotalScore(couCourseSelection));
244                 if(cou.getMethod().equals("考试"))
245                     System.out.println(cou.getName()+" "+getAvgDailyTotalScore(couCourseSelection)+ " "+
246                             getAvgFinalTotalScore(couCourseSelection)+" " +getAvgTotalScore(couCourseSelection));
247             }
248         }
249 //        System.out.println(courses.get(3).getMethod());
250     }
251     public void showClasses() {
252         Collections.sort(classes);
253         for(Class cla:classes){
254             //从总选课表listChooseCourse中获取该class的选课记录集合
255             ArrayList<Select> claCourseSelection = getClassselect(cla.getId());
256             if(claCourseSelection==null){
257                 System.out.println(cla.getId()+" has no grades yet");
258             } else{
259                 System.out.println(cla.getId()+" "+getAvgTotalScore(claCourseSelection));
260             }
261         }
262     }
263 
264     private String getAvgDailyTotalScore(ArrayList<Select> couCourseSelection) {
265         int sum = 0;
266 
267         for(Select select:couCourseSelection){
268             KsScore score = (KsScore) select.getScore();
269             sum+=score.getDailyScore();
270         }
271         return sum/couCourseSelection.size()+"";
272     }
273 
274     private String getAvgFinalTotalScore(ArrayList<Select> couCourseSelection) {
275         int sum = 0;
276         for(Select select:couCourseSelection){
277             sum+=select.getScore().getFinalScore();
278         }
279         return sum/couCourseSelection.size()+"";
280     }
281 
282     private String getAvgTotalScore(ArrayList<Select> stuCourseSelects) {
283         int sum = 0;
284         for(Select select:stuCourseSelects){
285             sum+=select.getScore().getTotalScore();
286         }
287         return sum/stuCourseSelects.size()+"";
288     }
289 
290     private ArrayList<Select> getClassselect(String id) {
291 //        Class class1 = new Class(id);
292         ArrayList<Select> selects1 = new ArrayList<>();
293         for(Select select:selects){
294             if(select.getStudent().getId().substring(0,6).equals(id))
295                 selects1.add(select);
296         }
297         if(selects1.size()!=0)
298             return selects1;
299         else return null;
300     }
301     private ArrayList<Select> getCourseselect(String name) {
302         ArrayList<Select> selects1 = new ArrayList<>();
303         for(Select select:selects){
304             if(select.getCourse().getName().equals(name))
305                 selects1.add(select);
306         }
307         if(selects1.size()!=0)
308             return selects1;
309         else return null;
310     }
311 
312     private ArrayList<Select> getStudentselects(String id) {
313         ArrayList<Select> selects1 = new ArrayList<>();
314         for(Select select:selects){
315             if(select.getStudent().getId().equals(id))
316                 selects1.add(select);
317         }
318         if(selects1.size()!=0)
319             return selects1;
320         else return null;
321     }
322 }
323 abstract class Score{
324      private int finalScore;
325      private int totalScore;
326     public int getFinalScore() {
327         return finalScore;
328     }
329     public void setFinalScore(int finalScore) {
330         this.finalScore = finalScore;
331     }
332 
333     public int getTotalScore() {
334         return finalScore;
335     }
336 
337     public void setTotalScore(int totalScore) {
338         this.totalScore = totalScore;
339     }
340 
341     public Score(int finalScore) {
342         this.finalScore = finalScore;
343     }
344 }
345 class KsScore extends Score{
346     private int dailyScore;
347     public int getDailyScore() {
348         return dailyScore;
349     }
350     public void setDailyScore(int dailyScore) {
351         this.dailyScore = dailyScore;
352     }
353     public int getTotalScore(){
354         double score;
355         score = dailyScore*0.3+getFinalScore()*0.7;
356         return (int)score;
357     }
358 
359     public KsScore(int dailyScore,int finalScore) {
360         super(finalScore);
361         this.dailyScore = dailyScore;
362     }
363 }
364 class KcScore extends Score{
365     public double getScore() {
366         return getFinalScore();
367     }
368 
369     public KcScore(int finalScore) {
370         super(finalScore);
371     }
372 
373 }
374 class Class implements Comparable<Class>{
375     private String id;
376     private List<Student> students = new ArrayList<>();
377     void addStudent(){
378         Student student = new Student();
379         students.add(student);
380     }
381     public Class(String id){
382         this.id = id;
383     }
384     public String getId() {
385         return id;
386     }
387 
388     public void setId(String id) {
389         this.id = id;
390     }
391 
392 
393 //    public int compareTo(Object o) {
394 //        return 0;
395 //    }
396     @Override
397     public int compareTo(Class o) {
398         return id.compareTo(o.id);
399     }
400 }
401 class Student implements Comparable<Student>{
402     private String id;
403     private String name;
404 
405     public String getId() {
406         return id;
407     }
408 
409     public void setId(String id) {
410         this.id = id;
411     }
412 
413     public String getName() {
414         return name;
415     }
416 
417     public void setName(String name) {
418         this.name = name;
419     }
420 
421     public Student() {}
422 
423     public Student(String id, String name) {
424         this.id = id;
425         this.name = name;
426     }
427 
428     @Override
429     public int compareTo(Student o) {
430         return id.compareTo(o.id);
431     }
432 //    public int compareTo(Course o) {
433 //        Comparator<Object> compare = Collator.getInstance(java.util.Locale.CHINA);
434 //        return compare.compare(name,o.getName());
435 //    }
436 }
437 class InputMatching {
438     static String stuNumMatching = "[0-9]{8}";//8个0-9的数字
439     static String stuNameMatching = "\\S{1,10}";//1到10个非空格(TAB)字符
440     static String scoreMatching = "([1-9]?[0-9]|100)";
441     static String courseNameMatching = "\\S{1,10}";//1到10个非空格(TAB)字符
442     static String courseTypeMatching = "(选修|必修)";
443     static String checkcourseTypeMatching = "(考试|考察)";
444     //cousrInput用于定义课程信息模式(正则表达式)
445     static String courseInput = courseNameMatching + "\\s" + courseTypeMatching + "\\s" + checkcourseTypeMatching;
446     //scoreInput用于定义成绩信息模式(正则表达式)
447     static String scoreInput = stuNumMatching + "\\s" + stuNameMatching + "\\s" + courseNameMatching + "\\s" +
448             scoreMatching + "(scoreMatching)?";
449     static String scoreInput1 = stuNumMatching + "\\s" + stuNameMatching + "\\s" + courseNameMatching + "\\s" +
450             scoreMatching + "\\s"+scoreMatching;
451     public static int matchingInput(String s) {
452         if (matchingCourse(s)) {
453             return 1;
454         }
455         if (matchingScore(s)) {
456             return 2;
457         }
458         return 0;
459     }
460 
461     private static boolean matchingCourse(String s) {
462         return s.matches(courseInput);
463     }
464 
465     private static boolean matchingScore(String s) {
466         //System.out.println(match);
467         return s.matches(scoreInput)||s.matches(scoreInput1);
468     }
469 }
View Code

第二次作业:

7-1 容器-HashMap-检索

分数 10
作者 蔡轲
单位 南昌航空大学

输入多个学生的成绩信息,包括:学号、姓名、成绩。

学号是每个学生的唯一识别号,互不相同。

姓名可能会存在重复。

使用HashMap存储学生信息,并实现根据学号的检索功能

输入格式:

输入多个学生的成绩信息,每个学生的成绩信息格式:学号+英文空格+姓名+英文空格+成绩

以“end”为输入结束标志

end之后输入某个学号,执行程序输出该生的详细信息

输出格式:

输出查询到的学生信息格式:学号+英文空格+姓名+英文空格+成绩

如果没有查询到,则输出:"The student "+查询的学号+" does not exist"

输入样例1:

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

20201107 张少军 83
20201116 李四 78
20201118 郑觉先 80
end
20201116

输出样例1:

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

20201116 李四 78

输入样例2:

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

20201107 张少军 83
20201116 李四 78
20201118 郑觉先 80
end
20202316

输出样例2:

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

The student 20202316 does not exist
 1 import java.util.HashMap;
 2 import java.util.Scanner;
 3 
 4 public class Main {
 5     public static void main(String[] args) {
 6         HashMap<String,String[]> map = new HashMap<>();
 7         Scanner input = new Scanner(System.in);
 8         String nextLine = input.nextLine();
 9         while (!nextLine.equals("end")){
10             String[] sr = nextLine.split(" ");
11             String[] a = new String[2];
12             a[0] = sr[1];
13             a[1] = sr[2];
14             map.put(sr[0],a);
15             nextLine = input.nextLine();
16         }
17         String check = input.nextLine();
18         String[] b = map.get(check);
19         if(b==null)
20             System.out.println("The student "+check+" does not exist");
21         else
22             System.out.println(check+" "+b[0]+" "+b[1]);
23     }
24 }
View Code

7-2 容器-HashMap-排序

分数 10
作者 蔡轲
单位 南昌航空大学

输入多个学生的成绩信息,包括:学号、姓名、成绩。

学号是每个学生的唯一识别号,互不相同。

姓名可能会存在重复。

要求:使用HashMap存储学生信息。

输入格式:

输入多个学生的成绩信息,每个学生的成绩信息格式:学号+英文空格+姓名+英文空格+成绩

以“end”为输入结束标志

输出格式:

按学号从大到小的顺序输出所有学生信息,每个学生信息的输出格式:学号+英文空格+姓名+英文空格+成绩

输入样例:

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

20201124 张少军 83
20201136 李四 78
20201118 郑觉先 80
end

输出样例:

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

20201136 李四 78
20201124 张少军 83
20201118 郑觉先 80
 1 import java.util.*;
 2 public class Main {
 3     public static void main(String[] args) {
 4         HashMap<String, String[]> map = new HashMap<>();
 5         Scanner input = new Scanner(System.in);
 6         String nextLine = input.nextLine();
 7         while (!nextLine.equals("end")) {
 8             String[] sr = nextLine.split(" ");
 9             String[] a = new String[2];
10             a[0] = sr[1];
11             a[1] = sr[2];
12             map.put(sr[0], a);
13             nextLine = input.nextLine();
14         }
15         List<String> key = new ArrayList<>();
16         for(Map.Entry<String, String[]> map1 : map.entrySet()) {
17             key.add(map1.getKey());
18         }
19         key.sort(Comparator.naturalOrder());//正向排序
20         for (int i = key.size()-1; i >= 0; i--) {
21             System.out.print(key.get(i));
22             String[] nameAndScore = map.get(key.get(i));
23             System.out.println(" " +nameAndScore[0]+" "+nameAndScore[1]);
24         }
25 
26     }
27 }
View Code

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.text.Collator;
  2 import java.util.*;
  3 
  4 public class Main {
  5     public static void main(String[] args) {
  6         ParseInput handle=new ParseInput();
  7         Scanner input = new Scanner(System.in);
  8         String nextLine = input.nextLine();
  9         while (!nextLine.equals("end")){
 10             handle.parseInput(nextLine);//解析用户输入的每一行数据
 11             nextLine = input.nextLine();
 12         }
 13         handle.showStudents();
 14         handle.showCourses();
 15         handle.showClasses();
 16     }
 17 }
 18 class Course implements Comparable<Course>{
 19     private String name;
 20     private String Type;
 21     private String method;
 22     public Course() {}
 23     public String getName() {
 24         return name;
 25     }
 26 
 27     public void setName(String name) {
 28         this.name = name;
 29     }
 30 
 31     public String getType() {
 32         return Type;
 33     }
 34 
 35     public void setType(String type) {
 36         Type = type;
 37     }
 38 
 39     public String getMethod() {
 40         return method;
 41     }
 42 
 43     public void setMethod(String method) {
 44         this.method = method;
 45     }
 46 
 47     public Course(String name, String type, String method) {
 48         this.name = name;
 49         Type = type;
 50         this.method = method;
 51     }
 52 
 53     @Override
 54     public int compareTo(Course o) {
 55         Comparator<Object> compare = Collator.getInstance(java.util.Locale.CHINA);
 56         return compare.compare(name,o.getName());
 57     }
 58 }
 59 class Select{
 60 
 61     private Student student = new Student();
 62     private Course course = new Course();
 63     private Score score;
 64 
 65     public Student getStudent() {
 66         return student;
 67     }
 68 
 69     public void setStudent(Student student) {
 70         this.student = student;
 71     }
 72 
 73     public Course getCourse() {
 74         return course;
 75     }
 76 
 77     public void setCourse(Course course) {
 78         this.course = course;
 79     }
 80 
 81     public Score getScore() {
 82         return score;
 83     }
 84 
 85     public void setScore(Score score) {
 86         this.score = score;
 87     }
 88 
 89     public Select(Student student, Course course, Score score) {
 90         this.student = student;
 91         this.course = course;
 92         this.score = score;
 93     }
 94 }
 95 class  ParseInput{
 96     private List<Student> students = new ArrayList<>();
 97     private List<Course> courses = new ArrayList<>();
 98     private List<Select> selects = new ArrayList<>();
 99     private List<Class> classes = new ArrayList<>();
100     void addStudent(String id,String name){
101         Student student = new Student(id,name);
102         if(selects.size()==0){
103             students.add(student);
104         }
105         else {
106             int flag=0;
107             for(Student student1:students){
108                 if ( student1.getId().equals(id)) {
109                     flag = 1;
110                     break;
111                 }
112             }
113             if(flag==0) students.add(student);
114         }
115     }
116     void addCourse(String name,String Type,String method){
117 
118         if(courses.size()==0){
119             Course course1 = new Course(name,Type,method);
120             courses.add(course1);
121         }
122         else {
123             int flag=0;
124             for(Course course:courses){
125                 if (course.getName().equals(name)) {
126                     flag = 1;
127                     break;
128                 }
129             }
130             if(flag==0) {
131                 Course course1 = new Course(name,Type,method);
132                 courses.add(course1);
133             }
134         }
135     }
136     void addSelect(Student student, Course course, Score score){
137 //        Select select = new Select(student,course,score);
138 //        selects.add(select);
139         if(selects.size()==0){
140             Select select = new Select(student,course,score);
141             selects.add(select);
142         }
143         else {
144             int flag=0;
145             for(Select select:selects){
146                 if (select.getStudent().getId().equals(student.getId())&&select.getCourse().getName().equals(course.getName())) {
147                     flag = 1;
148                     break;
149                 }
150             }
151             if(flag==0) {
152                 Select select = new Select(student,course,score);
153                 selects.add(select);
154             }
155         }
156     }
157     void addClass(String id){
158 
159         if(classes.size()==0){
160             Class aclass = new Class(id);
161             classes.add(aclass);
162         }
163         else {
164             int flag=0;
165             for (Class aclass:classes){
166                 if (aclass.getId().equals(id)) {
167                     flag = 1;
168                     break;
169                 }
170             }
171             if(flag==0){
172                 Class Aclass = new Class(id);
173                 classes.add(Aclass);
174             }
175         }
176     }
177     public void parseInput(String input) {
178         String[] sr = input.split(" ");
179         switch (InputMatching.matchingInput(input)){
180             case 0:
181                 System.out.println("wrong format");
182                 break;
183             case 1:{
184                 if(sr[1].equals("必修")&&sr[2].equals("考察")||(sr[1].equals("实验")&& !sr[1].equals(sr[2]))
185                         ||(sr[2].equals("实验")&&!sr[1].equals("实验")))
186                     System.out.println(sr[0]+" : course type & access mode mismatch");
187                 else addCourse(sr[0],sr[1],sr[2]);
188                 break;
189             }
190             case 2:{
191 
192                 addClass(sr[0].substring(0,6));
193                 Student student = new Student(sr[0],sr[1]);
194                 addStudent(sr[0],sr[1]);
195                 if(isCourseExist(sr[2])==null){
196                     System.out.println(sr[2]+" does not exist");
197                 }
198                 else {
199                     if(isCourseExist(sr[2]).getMethod().equals("考试")&&sr.length!=5
200                             ||isCourseExist(sr[2]).getMethod().equals("考察")&&sr.length!=4
201                             ||isCourseExist(sr[2]).getMethod().equals("实验")&&sr.length!=Integer.parseInt(sr[3])+4)
202                         System.out.println(sr[0]+" "+sr[1]+" : access mode mismatch");
203                     else if(sr.length==4){
204                         Score score = new KcScore(Integer.parseInt(sr[3]));
205                         addSelect(student,isCourseExist(sr[2]),score);
206                     }
207                     else if(sr.length==5){
208                         Score score = new KsScore(Integer.parseInt(sr[3]),Integer.parseInt(sr[4]));
209                         addSelect(student,isCourseExist(sr[2]),score);
210                     }
211                     else{
212                         int n= Integer.parseInt(sr[3]);
213                         int [] a = new int[n];
214                         for(int i= 0;i<n;i++){
215                             a[i] = Integer.parseInt(sr[i+4]);
216                         }
217                         Score score = new SyScore(0,n,a);
218                         addSelect(student,isCourseExist(sr[2]),score);
219                     }
220                 }
221             }
222         }
223     }
224     public Course isCourseExist(String name) {
225         for (Course course : courses) {
226             if (course.getName().equals(name))
227                 return course;
228         }
229         return null;
230     }
231     public void showStudents() {
232         Collections.sort(students);
233         for (Student stu : students) {
234             //从总选课表listChooseCourse中获取该生的选课记录集合
235             ArrayList<Select> stuCourseSelects = getStudentselects(stu.getId());
236             if (stuCourseSelects == null) {
237                 System.out.println(stu.getId() + " " + stu.getName() + " " + "did not take any exams");
238             } else {
239                 System.out.println(stu.getId() + " " + stu.getName() + " "
240                         + getAvgTotalScore(stuCourseSelects));
241             }
242         }
243     }
244     public void showCourses() {
245         Collections.sort(courses);
246         for(Course cou:courses){
247             //从总选课表listChooseCourse中获取该course的选课记录集合
248             ArrayList<Select> couCourseSelection = getCourseselect(cou.getName());
249             if(couCourseSelection==null){
250                 System.out.println(cou.getName()+" has no grades yet");
251             } else {
252                 if(cou.getMethod().equals("考察"))
253                     System.out.println(cou.getName()+" "+getAvgFinalTotalScore(couCourseSelection)+" "
254                             +getAvgTotalScore(couCourseSelection));
255                 if(cou.getMethod().equals("考试"))
256                     System.out.println(cou.getName()+" "+getAvgDailyTotalScore(couCourseSelection)+ " "+
257                             getAvgFinalTotalScore(couCourseSelection)+" " +getAvgTotalScore(couCourseSelection));
258                 if(cou.getMethod().equals("实验"))
259                     System.out.println(cou.getName()+" "+getAvgTotalScore(couCourseSelection));
260             }
261         }
262 //        System.out.println(courses.get(3).getMethod());
263     }
264     public void showClasses() {
265         Collections.sort(classes);
266         for(Class cla:classes){
267             //从总选课表listChooseCourse中获取该class的选课记录集合
268             ArrayList<Select> claCourseSelection = getClassselect(cla.getId());
269             if(claCourseSelection==null){
270                 System.out.println(cla.getId()+" has no grades yet");
271             } else{
272                 System.out.println(cla.getId()+" "+getAvgTotalScore(claCourseSelection));
273             }
274         }
275     }
276 
277     private String getAvgDailyTotalScore(ArrayList<Select> couCourseSelection) {
278         int sum = 0;
279 
280         for(Select select:couCourseSelection){
281             KsScore score = (KsScore) select.getScore();
282             sum+=score.getDailyScore();
283         }
284         return sum/couCourseSelection.size()+"";
285     }
286 
287     private String getAvgFinalTotalScore(ArrayList<Select> couCourseSelection) {
288         int sum = 0;
289         for(Select select:couCourseSelection){
290             sum+=select.getScore().getFinalScore();
291         }
292         return sum/couCourseSelection.size()+"";
293     }
294 
295     private String getAvgTotalScore(ArrayList<Select> stuCourseSelects) {
296         int sum = 0;
297         for(Select select:stuCourseSelects){
298             sum+=select.getScore().getTotalScore();
299         }
300         return sum/stuCourseSelects.size()+"";
301     }
302 
303     private ArrayList<Select> getClassselect(String id) {
304 //        Class class1 = new Class(id);
305         ArrayList<Select> selects1 = new ArrayList<>();
306         for(Select select:selects){
307             if(select.getStudent().getId().substring(0,6).equals(id))
308                 selects1.add(select);
309         }
310         if(selects1.size()!=0)
311             return selects1;
312         else return null;
313     }
314     private ArrayList<Select> getCourseselect(String name) {
315         ArrayList<Select> selects1 = new ArrayList<>();
316         for(Select select:selects){
317             if(select.getCourse().getName().equals(name))
318                 selects1.add(select);
319         }
320         if(selects1.size()!=0)
321             return selects1;
322         else return null;
323     }
324 
325     private ArrayList<Select> getStudentselects(String id) {
326         ArrayList<Select> selects1 = new ArrayList<>();
327         for(Select select:selects){
328             if(select.getStudent().getId().equals(id))
329                 selects1.add(select);
330         }
331         if(selects1.size()!=0)
332             return selects1;
333         else return null;
334     }
335 }
336 abstract class Score{
337     private int finalScore;
338     private int totalScore;
339     public int getFinalScore() {
340         return finalScore;
341     }
342     public void setFinalScore(int finalScore) {
343         this.finalScore = finalScore;
344     }
345 
346     public int getTotalScore() {
347         return finalScore;
348     }
349 
350     public void setTotalScore(int totalScore) {
351         this.totalScore = totalScore;
352     }
353 
354     public Score(int finalScore) {
355         this.finalScore = finalScore;
356     }
357 }
358 class KcScore extends Score{
359     public double getScore() {
360         return getFinalScore();
361     }
362 
363     public KcScore(int finalScore) {
364         super(finalScore);
365     }
366 
367 }
368 class KsScore extends Score{
369     private int dailyScore;
370     public int getDailyScore() {
371         return dailyScore;
372     }
373     public void setDailyScore(int dailyScore) {
374         this.dailyScore = dailyScore;
375     }
376     public int getTotalScore(){
377         double score;
378         score = dailyScore*0.3+getFinalScore()*0.7;
379         return (int)score;
380     }
381 
382     public KsScore(int dailyScore,int finalScore) {
383         super(finalScore);
384         this.dailyScore = dailyScore;
385     }
386 }
387 class SyScore extends Score{
388     int n;
389     int [] a;
390     public SyScore(int finalScore,int n,int [] a) {
391         super(finalScore);
392         this.a = a;
393         this.n = n;
394     }
395 
396     @Override
397     public int getTotalScore() {
398         int sum = 0;
399         for(int i=0;i<n;i++){
400             sum+=a[i];
401         }
402         return sum/n;
403     }
404 }
405 class Class implements Comparable<Class>{
406     private String id;
407     private List<Student> students = new ArrayList<>();
408     void addStudent(){
409         Student student = new Student();
410         students.add(student);
411     }
412     public Class(String id){
413         this.id = id;
414     }
415     public String getId() {
416         return id;
417     }
418 
419     public void setId(String id) {
420         this.id = id;
421     }
422 
423 
424     //    public int compareTo(Object o) {
425 //        return 0;
426 //    }
427     @Override
428     public int compareTo(Class o) {
429         return id.compareTo(o.id);
430     }
431 }
432 class Student implements Comparable<Student>{
433     private String id;
434     private String name;
435 
436     public String getId() {
437         return id;
438     }
439 
440     public void setId(String id) {
441         this.id = id;
442     }
443 
444     public String getName() {
445         return name;
446     }
447 
448     public void setName(String name) {
449         this.name = name;
450     }
451 
452     public Student() {}
453 
454     public Student(String id, String name) {
455         this.id = id;
456         this.name = name;
457     }
458 
459     @Override
460     public int compareTo(Student o) {
461         return id.compareTo(o.id);
462     }
463 //    public int compareTo(Course o) {
464 //        Comparator<Object> compare = Collator.getInstance(java.util.Locale.CHINA);
465 //        return compare.compare(name,o.getName());
466 //    }
467 }
468 class InputMatching {
469     static String stuNumMatching = "[0-9]{8}";//8个0-9的数字
470     static String stuNameMatching = "\\S{1,10}";//1到10个非空格(TAB)字符
471     static String scoreMatching = "([1-9]?[0-9]|100)";
472     static String scoreMatching1 = "([1-9]\\d{0,1}|0|100)( ([1-9]\\d{0,1}|0|100)){3,8}";
473     static String courseNameMatching = "\\S{1,10}";//1到10个非空格(TAB)字符
474     static String courseTypeMatching = "(选修|必修|实验)";
475     static String checkcourseTypeMatching = "(考试|考察|实验)";
476     static String experimentNumber = "[4-9]";
477     //cousrInput用于定义课程信息模式(正则表达式)
478     static String courseInput = courseNameMatching + " " + courseTypeMatching + " " + checkcourseTypeMatching;
479     //scoreInput用于定义成绩信息模式(正则表达式)
480     static String scoreInput = stuNumMatching + " " + stuNameMatching + " " + courseNameMatching + " " + scoreMatching;
481 
482     static String scoreInput1 = stuNumMatching + " " + stuNameMatching + " " + courseNameMatching + " " + scoreMatching + " "+scoreMatching;
483 
484     static String scoreInput2 = stuNumMatching + " " + stuNameMatching + " " + courseNameMatching + " " + experimentNumber + " " +scoreMatching + " "+scoreMatching+ " "+scoreMatching;
485 
486     static String scoreInput4 = stuNumMatching + " " + stuNameMatching + " " + courseNameMatching + " " + experimentNumber + " " +scoreMatching1;
487     public static int matchingInput(String s) {
488         if (matchingCourse(s)) {
489             return 1;
490         }
491         if (matchingScore(s)) {
492             return 2;
493         }
494         return 0;
495     }
496 
497     private static boolean matchingCourse(String s) {
498         return s.matches(courseInput);
499     }
500     private static boolean matchingScore(String s) {
501         return (s.matches(scoreInput)||s.matches(scoreInput1)||s.matches(scoreInput2)||s.matches(scoreInput4));
502     }
503 }
View Code

7-4 动物发声模拟器(多态)

分数 20
作者 刘凤良
单位 天津仁爱学院

设计一个动物发生模拟器,用于模拟不同动物的叫声。比如狮吼、虎啸、狗旺旺、猫喵喵……。
定义抽象类Animal,包含两个抽象方法:获取动物类别getAnimalClass()、动物叫shout();
然后基于抽象类Animal定义狗类Dog、猫类Cat和山羊Goat,用getAnimalClass()方法返回不同的动物类别(比如猫,狗,山羊),用shout()方法分别输出不同的叫声(比如喵喵、汪汪、咩咩)。
最后编写AnimalShoutTest类测试,输出:
猫的叫声:喵喵
狗的叫声:汪汪
山羊的叫声:咩咩

其中,在AnimalShoutTestMain类中,用speak(Animal animal){}方法输出动物animal的叫声,在main()方法中调用speak()方法,分别输出猫、狗和山羊对象的叫声。

请在下面的【】处添加代码。

 1 //动物发生模拟器.  请在下面的【】处添加代码。
 2 public class AnimalShoutTest2 {
 3     public static void main(String[] args) {        
 4          Cat cat = new Cat();
 5          Dog dog = new Dog();        
 6         Goat goat = new Goat();
 7          speak(cat);
 8          speak(dog);
 9          speak(goat);
10     }
11     //定义静态方法speak()
12     【】
13 
14 }
15 
16 //定义抽象类Animal
17 【】class Animal{
18     【】
19 }
20 //基于Animal类,定义猫类Cat,并重写两个抽象方法
21 class Cat 【】{
22     【】    
23     【】
24 }
25 //基于Animal类,定义狗类Dog,并重写两个抽象方法
26 class Dog 【】{
27     【】
28     【】
29 }
30 //基于Animal类,定义山羊类Goat,并重写两个抽象方法
31 class Goat 【】{
32     【】
33     【】
34 }

输入样例:

 

输出样例:

猫的叫声:喵喵
狗的叫声:汪汪
山羊的叫声:咩咩
public class Main {
    public static void main(String[] args) {
        Cat cat = new Cat();
        Dog dog = new Dog();
        Goat goat = new Goat();
        speak(cat);
        speak(dog);
        speak(goat);
    }
    //定义静态方法speak()
    public static void speak(Animal animal){
        System.out.println(animal.getAnimal()+"的叫声:"+animal.outPut());
    }

}

//定义抽象类Animal
abstract class Animal{
    abstract String getAnimal();
    abstract String outPut();

}
//基于Animal类,定义猫类Cat,并重写两个抽象方法
class Cat extends Animal{

    @Override
    String getAnimal() {
        return "猫";
    }

    @Override
    String outPut() {
        return "喵喵";
    }
}
//基于Animal类,定义狗类Dog,并重写两个抽象方法
class Dog extends Animal{

    @Override
    String getAnimal() {
        return "狗";
    }

    @Override
    String outPut() {
        return "汪汪";
    }
}
//基于Animal类,定义山羊类Goat,并重写两个抽象方法
class Goat extends Animal{

    @Override
    String getAnimal() {
        return "山羊";
    }

    @Override
    String outPut() {
        return "咩咩";
    }
}
View Code

第三次作业:

7-1 容器-ArrayList-排序

分数 12
作者 蔡轲
单位 南昌航空大学

题目描述

编辑

输入多个学生的成绩信息,包括:学号、姓名、数学成绩、物理成绩。

学号是每个学生的唯一识别号,互不相同。

姓名可能会存在重复。

要求:使用ArrayList存储学生信息。

输入格式:

输入多个学生的成绩信息,每个学生的成绩信息格式:学号+英文空格+姓名+英文空格+数学成绩+英文空格+物理成绩

以“end”为输入结束标志

输出格式:

按数学/物理成绩之和从高到低的顺序输出所有学生信息,每个学生信息的输出格式:学号+英文空格+姓名+英文空格+数学/物理成绩之和

成绩相同的情况,按输入的先后顺序输出。

输入样例:

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

20201124 张少军 83 75
20201136 李四 78 86
20201118 郑觉先 80 62
end

输出样例:

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

20201136 李四 164
20201124 张少军 158
20201118 郑觉先 142
import java.util.ArrayList;
import java.util.Scanner;
import java.util.Collections;

public class Main {
    public static void main(String[] args) {
        Scanner input = new Scanner(System.in);
        ArrayList<Student> students = new ArrayList<>();
        // 输入学生信息,直到输入 end 结束
        while (true) {
            String line = input.nextLine();
            if (line.equals("end")) {
                break;
            }
            String[] sr = line.split(" ");
            String id = sr[0];
            String name = sr[1];
            int mathScore = Integer.parseInt(sr[2]);
            int physScore = Integer.parseInt(sr[3]);

            Student student = new Student(id, name, mathScore, physScore);
            students.add(student);
        }

        // 按照总成绩排序
        Collections.sort(students);

        // 输出结果
        for (Student student : students) {
            System.out.println(student.getId() + " " + student.getName() + " " + student.getTotalScore());
        }
    }
}

class Student implements Comparable<Student> {
    private String id;
    private String name;
    private int mathScore;
    private int physScore;

    public Student(String id, String name, int mathScore, int physScore) {
        this.id = id;
        this.name = name;
        this.mathScore = mathScore;
        this.physScore = physScore;
    }

    public String getId() {
        return id;
    }

    public String getName() {
        return name;
    }

    public int getTotalScore() {
        return mathScore + physScore;
    }

    @Override
    public int compareTo(Student o) {
        // 先按总成绩从高到低排序
        int totalScoreComp = Integer.compare(o.getTotalScore(), getTotalScore());
        // if (totalScoreComp != 0) {
        //     return totalScoreComp;
        // }

        // // 如果总成绩相同,按输入的先后顺序输出
        // return -1;
        return totalScoreComp;
    }
}
View Code

7-2 课程成绩统计程序-3

分数 64
作者 蔡轲
单位 南昌航空大学

课程成绩统计程序-3在第二次的基础上修改了计算总成绩的方式,

要求:修改类结构,将成绩类的继承关系改为组合关系,成绩信息由课程成绩类和分项成绩类组成,课程成绩类组合分项成绩类,分项成绩类由成绩分值和权重两个属性构成。

完成课程成绩统计程序-2、3两次程序后,比较继承和组合关系的区别。思考一下哪一种关系运用上更灵活,更能够适应变更。

题目最后的参考类图未做修改,大家根据要求自行调整,以下内容加粗字体显示的内容为本次新增的内容。

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

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

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

实验的总成绩等于课程每次实验成绩乘以权重后累加而得。

课程权重值在录入课程信息时输入。(注意:所有分项成绩的权重之和应当等于1)

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

1、输入:

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

课程信息包括:课程名称、课程性质、考核方式、分项成绩数量、每个分项成绩的权重。

考试课信息格式:课程名称+英文空格+课程性质+英文空格+考核方式+英文空格+平时成绩的权重+英文空格+期末成绩的权重

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

实验课程信息格式:课程名称+英文空格+课程性质+英文空格+考核方式+英文空格+分项成绩数量n+英文空格+分项成绩1的权重+英文空格+。。。+英文空格+分项成绩n的权重

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

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

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

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

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

实验课程成绩信息包括:学号、姓名、课程名称、每次成绩{在系列-2的基础上去掉了(实验次数),实验次数要和实验课程信息中输入的分项成绩数量保持一致}

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

以上信息的相关约束:

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

2)学号由8位数字组成

3)姓名不超过10个字符

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

5)不特别输入班级信息,班级号是学号的前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)若出现重复的课程/成绩信息,只保留第一个课程信息,忽略后面输入的。

6)如果解析实验课程信息时,输入的分项成绩数量值和分项成绩权重的个数不匹配,输出:课程名称+" : number of scores does not match"

7)如果解析考试课、实验课时,分项成绩权重值的总和不等于1,输出:课程名称+" : weight value error"

信息约束:

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

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

fdada4ca193119ee30531ab82ffebbfa_9dbcf4e8-1627-4cf6-8764-cccf44947e2a.png

输入样例1:

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

java 实验 实验 4 0.2 0.3 0.2 0.3
end

输出样例1:

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

java has no grades yet

输入样例2:

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

java 实验 实验 4 0.2 0.3 0.2
end

输出样例2:

在这里给出相应的输出。例如:
java : number of scores does not match

输入样例3:

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

java 实验 实验 4 0.2 0.3 0.2 0.1
end

输出样例3:

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

java : weight value error

输入样例4:

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

java 实验 实验 4 0.2 0.3 0.2 0.3
20201116 张三 java 70 80 90 100
end

输出样例4:

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

20201116 张三 86
java 86
202011 86

输入样例5:

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

java 实验 实验 4 0.2 0.3 0.2 0.3
20201116 张三 java 70 80 90 100 80
end
 

输出样例5:

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

20201116 张三 : access mode mismatch
20201116 张三 did not take any exams
java has no grades yet
202011 has no grades yet
import java.text.Collator;
import java.util.*;

public class Main {
    public static void main(String[] args) {
        ParseInput handle=new ParseInput();
        Scanner input = new Scanner(System.in);
        String nextLine = input.nextLine();
        while (!nextLine.equals("end")){
            handle.parseInput(nextLine);//解析用户输入的每一行数据
            nextLine = input.nextLine();
        }
        handle.showStudents();
        handle.showCourses();
        handle.showClasses();
    }
}
class Course implements Comparable<Course>{
    private String name;
    private String Type;
    private String method;
    private int n;
    private float [] value;
    public Course() {}
    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getType() {
        return Type;
    }

    public void setType(String type) {
        Type = type;
    }

    public String getMethod() {
        return method;
    }

    public void setMethod(String method) {
        this.method = method;
    }

    public int getN() {
        return n;
    }

    public void setN(int n) {
        this.n = n;
    }

    public float[] getValue() {
        return value;
    }

    public void setValue(float[] value) {
        this.value = value;
    }

    public Course(String name, String type, String method, int n, float[] value) {
        this.name = name;
        Type = type;
        this.method = method;
        this.n = n;
        this.value = value;
    }

    @Override
    public int compareTo(Course o) {
        Comparator<Object> compare = Collator.getInstance(java.util.Locale.CHINA);
        return compare.compare(name,o.getName());
    }
}
class Select{

    private Student student = new Student();
    private Course course = new Course();
    private Score score;

    public Student getStudent() {
        return student;
    }

    public void setStudent(Student student) {
        this.student = student;
    }

    public Course getCourse() {
        return course;
    }

    public void setCourse(Course course) {
        this.course = course;
    }

    public Score getScore() {
        return score;
    }

    public void setScore(Score score) {
        this.score = score;
    }

    public Select(Student student, Course course, Score score) {
        this.student = student;
        this.course = course;
        this.score = score;
    }
}
class  ParseInput{
    private List<Student> students = new ArrayList<>();
    private List<Course> courses = new ArrayList<>();
    private List<Select> selects = new ArrayList<>();
    private List<Class> classes = new ArrayList<>();
    void addStudent(String id,String name){
        Student student = new Student(id,name);
        if(selects.size()==0){
            students.add(student);
        }
        else {
            int flag=0;
            for(Student student1:students){
                if ( student1.getId().equals(id)) {
                    flag = 1;
                    break;
                }
            }
            if(flag==0) students.add(student);
        }
    }
    void addCourse(String name,String Type,String method,int n,float [] value){

        if(courses.size()==0){
            Course course1 = new Course(name,Type,method,n,value);
            courses.add(course1);
        }
        else {
            int flag=0;
            for(Course course:courses){
                if (course.getName().equals(name)) {
                    flag = 1;
                    break;
                }
            }
            if(flag==0) {
                Course course1 = new Course(name,Type,method,n,value);
                courses.add(course1);
            }
        }
    }
    void addSelect(Student student, Course course, Score score){
//        Select select = new Select(student,course,score);
//        selects.add(select);
        if(selects.size()==0){
            Select select = new Select(student,course,score);
            selects.add(select);
        }
        else {
            int flag=0;
            for(Select select:selects){
                if (select.getStudent().getId().equals(student.getId())&&select.getCourse().getName().equals(course.getName())) {
                    flag = 1;
                    break;
                }
            }
            if(flag==0) {
                Select select = new Select(student,course,score);
                selects.add(select);
            }
        }
    }
    void addClass(String id){

        if(classes.size()==0){
            Class aclass = new Class(id);
            classes.add(aclass);
        }
        else {
            int flag=0;
            for (Class aclass:classes){
                if (aclass.getId().equals(id)) {
                    flag = 1;
                    break;
                }
            }
            if(flag==0){
                Class Aclass = new Class(id);
                classes.add(Aclass);
            }
        }
    }
    public void parseInput(String input) {
        String[] sr = input.split(" ");
        switch (InputMatching.matchingInput(input)){
            case 0:
                System.out.println("wrong format");
                break;
            case 1:{
                if(sr[1].equals("必修")&&sr[2].equals("考察")||(sr[1].equals("实验")&& !sr[1].equals(sr[2]))
                        ||(sr[2].equals("实验")&&!sr[1].equals("实验")))
                    System.out.println(sr[0]+" : course type & access mode mismatch");
                else{
                    if(sr[2].equals("考试")){
                        if(sr.length==5){
                            float [] value = new float[2];
                            value[0] = Float.parseFloat(sr[3]);
                            value[1] = Float.parseFloat(sr[4]);
                            float sumValue = value[0]+value[1];
                            if((sumValue<0.99||sumValue>1.01)&&isCourseExist(sr[0])==null)
                                System.out.println(sr[0]+" : weight value error");
                            else addCourse(sr[0],sr[1],sr[2],2,value);
                        }
                        else System.out.println("wrong format");
                    }
                    if(sr[2].equals("考察")){
                        if(sr.length==3) addCourse(sr[0],sr[1],sr[2],1,null);
                        else System.out.println("wrong format");                    }
                    if(sr[2].equals("实验")){
                        float sumValue = 0;
                        int n = Integer.parseInt(sr[3]);
                        if(sr.length!=n+4)
                            System.out.println(sr[0]+" : number of scores does not match");
                        else{
                            float [] value = new float[n];
                            for(int i= 0;i<n;i++){
                                value[i] = Float.parseFloat(sr[i+4]);
                                sumValue+=value[i];
                            }
                            if((sumValue<0.99||sumValue>1.01)&&isCourseExist(sr[0])==null)
                                System.out.println(sr[0]+" : weight value error");
                            else addCourse(sr[0],sr[1],sr[2],n,value);}

                    }
                }
                break;
            }
            case 2:{
                addClass(sr[0].substring(0,6));
                Student student = new Student(sr[0],sr[1]);
                addStudent(sr[0],sr[1]);
                if(isCourseExist(sr[2])==null){
                    System.out.println(sr[2]+" does not exist");
                }
                else {
                    if(isCourseExist(sr[2]).getMethod().equals("考试")&&sr.length!=5
                            ||isCourseExist(sr[2]).getMethod().equals("考察")&&sr.length!=4
                            ||isCourseExist(sr[2]).getMethod().equals("实验")&&sr.length!=3+isCourseExist(sr[2]).getN())
                        System.out.println(sr[0]+" "+sr[1]+" : access mode mismatch");
                    else if(sr.length==4){
                        SubScore subScore = new SubScore(1.0F,Integer.parseInt(sr[3]));
                        Score score = new Score(sr[0]);
                        score.addSubScore(subScore);
                        addSelect(student,isCourseExist(sr[2]),score);
                    }
                    else if(sr.length==5){
                        float [] value = isCourseExist(sr[2]).getValue();
                        SubScore subScore1 = new SubScore(value[0], Integer.parseInt(sr[3]));
                        SubScore subScore2 = new SubScore(value[1], Integer.parseInt(sr[4]));
                        Score score = new Score(sr[2]);
                        score.addSubScore(subScore1);
                        score.addSubScore(subScore2);
                        addSelect(student,isCourseExist(sr[2]),score);
                    }
                    else{
                        Score score = new Score(sr[2]);
                        int n = isCourseExist(sr[2]).getN();
                        float [] value = isCourseExist(sr[2]).getValue();
                        for(int i= 0;i<n;i++){
                            SubScore subScore = new SubScore(value[i],Integer.parseInt(sr[i+3]));
                            score.addSubScore(subScore);
                        }
                        addSelect(student,isCourseExist(sr[2]),score);                    }
                }
            }
        }
    }
    public Course isCourseExist(String name) {
        for (Course course : courses) {
            if (course.getName().equals(name))
                return course;
        }
        return null;
    }
    public void showStudents() {
        Collections.sort(students);
        for (Student stu : students) {
            //从总选课表listChooseCourse中获取该生的选课记录集合
            ArrayList<Select> stuCourseSelects = getStudentselects(stu.getId());
            if (stuCourseSelects == null) {
                System.out.println(stu.getId() + " " + stu.getName() + " " + "did not take any exams");
            } else {
                System.out.println(stu.getId() + " " + stu.getName() + " "
                        + getAvgTotalScore(stuCourseSelects));
            }
        }
    }
    public void showCourses() {
        Collections.sort(courses);
        for(Course cou:courses){
            //从总选课表listChooseCourse中获取该course的选课记录集合
            ArrayList<Select> couCourseSelection = getCourseselect(cou.getName());
            if(couCourseSelection==null){
                System.out.println(cou.getName()+" has no grades yet");
            } else {
                System.out.println(cou.getName()+" "+getAvgTotalScore(couCourseSelection));
            }
        }
    }
    public void showClasses() {
        Collections.sort(classes);
        for(Class cla:classes){
            //从总选课表listChooseCourse中获取该class的选课记录集合
            ArrayList<Select> claCourseSelection = getClassselect(cla.getId());
            if(claCourseSelection==null){
                System.out.println(cla.getId()+" has no grades yet");
            } else{
                System.out.println(cla.getId()+" "+getAvgTotalScore(claCourseSelection));
            }
        }
    }
    private String getAvgTotalScore(ArrayList<Select> stuCourseSelects) {
        int sum = 0;
        for(Select select:stuCourseSelects){
            sum+=select.getScore().getTotalScore();
        }
        return sum/stuCourseSelects.size()+"";
    }

    private ArrayList<Select> getClassselect(String id) {
        ArrayList<Select> selects1 = new ArrayList<>();
        for(Select select:selects){
            if(select.getStudent().getId().substring(0,6).equals(id))
                selects1.add(select);
        }
        if(selects1.size()!=0)
            return selects1;
        else return null;
    }
    private ArrayList<Select> getCourseselect(String name) {
        ArrayList<Select> selects1 = new ArrayList<>();
        for(Select select:selects){
            if(select.getCourse().getName().equals(name))
                selects1.add(select);
        }
        if(selects1.size()!=0)
            return selects1;
        else return null;
    }

    private ArrayList<Select> getStudentselects(String id) {
        ArrayList<Select> selects1 = new ArrayList<>();
        for(Select select:selects){
            if(select.getStudent().getId().equals(id))
                selects1.add(select);
        }
        if(selects1.size()!=0)
            return selects1;
        else return null;
    }
}
class Score{
    private String courseName;
    private List<SubScore> subScoreList;

    public Score(String courseName) {
        this.courseName = courseName;
        subScoreList = new ArrayList<>();
    }

    public void addSubScore(SubScore subScore) {
        subScoreList.add(subScore);
    }

    public int getTotalScore() {
        float totalScore = 0;
        for (SubScore subScore : subScoreList) {
            totalScore += subScore.getScore();
        }
        return (int)totalScore;
    }

    public String getCourseName() {
        return courseName;
    }

}

class SubScore {
    private float scoreValue;
    private int weight;

    public SubScore(float scoreValue, int weight) {
        this.scoreValue = scoreValue;
        this.weight = weight;
    }

    public float getScore() {
        return scoreValue * weight;
    }

    public float getScoreValue() {
        return scoreValue;
    }

    public int getWeight() {
        return weight;
    }
}

class Class implements Comparable<Class>{
    private String id;
    private List<Student> students = new ArrayList<>();
    void addStudent(){
        Student student = new Student();
        students.add(student);
    }
    public Class(String id){
        this.id = id;
    }
    public String getId() {
        return id;
    }

    public void setId(String id) {
        this.id = id;
    }

    @Override
    public int compareTo(Class o) {
        return id.compareTo(o.id);
    }
}
class Student implements Comparable<Student>{
    private String id;
    private String name;

    public String getId() {
        return id;
    }

    public void setId(String id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public Student() {}

    public Student(String id, String name) {
        this.id = id;
        this.name = name;
    }

    @Override
    public int compareTo(Student o) {
        return id.compareTo(o.id);
    }
}
class InputMatching {
    static String stuNumMatching = "[0-9]{8}";//8个0-9的数字
    static String stuNameMatching = "\\S{1,10}";//1到10个非空格(TAB)字符
    static String scoreMatching = "([1-9]?[0-9]|100)";
    static String scoreMatching1 = "([1-9]\\d{0,1}|0|100)( ([1-9]\\d{0,1}|0|100)){1,9}";
    static String courseNameMatching = "\\S{1,10}";//1到10个非空格(TAB)字符
    static String decimalsRegex = "(\\d+\\.\\d+)( (\\d+\\.\\d+)){2,9}";
    static String experimentNumber = "[4-9]";//实验次数
    static String decimals = "\\d+\\.\\d+";//小数
    //cousrInput用于定义课程信息模式(正则表达式)
    static String courseInput = courseNameMatching + " " + "选修" + " " + "考察";
    static String courseInput0 = courseNameMatching + " " + "必修" + " " + "考试"+ " " + decimals + " " + decimals;
    static String courseInput2 = courseNameMatching + " " + "选修" + " " + "考试"+ " " + decimals + " " + decimals;
    static String courseInput1 = courseNameMatching + " " + "实验" + " " + "实验" + " " + experimentNumber + " " + decimalsRegex;
    //scoreInput用于定义成绩信息模式(正则表达式)
    static String scoreInput = stuNumMatching + " " + stuNameMatching + " " + courseNameMatching + " " + scoreMatching;
    static String scoreInput1 = stuNumMatching + " " + stuNameMatching + " " + courseNameMatching +" "+scoreMatching1;
    public static int matchingInput(String s) {
        if (matchingCourse(s)) {
            return 1;
        }
        if (matchingScore(s)) {
            return 2;
        }
        return 0;
    }
    private static boolean matchingCourse(String s) {
        return (s.matches(courseInput)||s.matches(courseInput1)||s.matches(courseInput0)||s.matches(courseInput2));
    }
    private static boolean matchingScore(String s) {
        return (s.matches(scoreInput)||s.matches(scoreInput1));
    }
}
View Code

7-3 jmu-Java-02基本语法-03-身份证排序

分数 9
作者 郑如滨
单位 集美大学
  1. 输入n,然后连续输入n个身份证号。
  2. 然后根据输入的是sort1还是sort2,执行不同的功能。输入的不是sort1或sort2,则输出exit并退出。
    输入sort1,将每个身份证的年月日抽取出来,按年-月-日格式组装,然后对组装后的年-月-日升序输出。
    输入sort2,将所有身份证按照里面的年月日升序输出。

注意:处理输入的时候,全部使用ScannernextLine()方法,以免出错。

输入样例:

6
410425198309308225
320203197206115011
431227196108033146
330226196605054190
34080019810819327X
320111197112301539
sort1
sort2
e

输出样例:

1961-08-03
1966-05-05
1971-12-30
1972-06-11
1981-08-19
1983-09-30
431227196108033146
330226196605054190
320111197112301539
320203197206115011
34080019810819327X
410425198309308225
exit
import java.util.*;
public class Main {
    public static void main(String[] args) {
        HashMap<String,String> map = new HashMap<>();
        Scanner input = new Scanner(System.in);
        int n = input.nextInt();
        for (int i = 0; i < n; i++) {
            String id = input.next();
            String date = parseInput(id);
            map.put(date,id);
        }
        List<String> key = new ArrayList<>();
        for(Map.Entry<String, String>map1 : map.entrySet()) {
            key.add(map1.getKey());
        }
        key.sort(Comparator.naturalOrder());
        while (true){
            String sr = input.next();
            if (!sr.equals("sort1")&&!sr.equals("sort2")) {
                break;
            }
            if (sr.equals("sort1")) {//key
                for (int i =0;i <= key.size()-1; i++)
                    System.out.println(key.get(i));
            } else {//value
                for (int i =0;i <= key.size()-1; i++){
                    String id = map.get(key.get(i));
                    System.out.println(id);
                }
            }
        }
        System.out.println("exit");
        input.close();
    }
    private static String parseInput(String id) {
        String year = id.substring(6, 10);
        String month = id.substring(10, 12);
        String day = id.substring(12, 14);
        return year + "-" + month + "-" + day;
    }
}
View Code

7-4 jmu-Java-04面向对象进阶-03-接口-自定义接口ArrayIntegerStack

分数 10
作者 郑如滨
单位 集美大学

定义IntegerStack接口,用于声明一个存放Integer元素的栈的常见方法:

1 public Integer push(Integer item);
2 //如果item为null,则不入栈直接返回null。如果栈满,也返回null。如果插入成功,返回item。
3 
4 public Integer pop();   //出栈,如果为空,则返回null。出栈时只移动栈顶指针,相应位置不置为null
5 public Integer peek();  //获得栈顶元素,如果为空,则返回null.
6 public boolean empty(); //如果为空返回true
7 public int size();      //返回栈中元素个数

定义IntegerStack的实现类ArrayIntegerStack,内部使用数组实现。创建时,可指定内部数组大小。

main方法说明
  1. 输入n,建立可包含n个元素的ArrayIntegerStack对象
  2. 输入m个值,均入栈。每次入栈均打印入栈返回结果。
  3. 输出栈顶元素,输出是否为空,输出size
  4. 使用Arrays.toString()输出内部数组中的值。
  5. 输入x,然后出栈x次,每次出栈均打印。
  6. 输出栈顶元素,输出是否为空,输出size
  7. 使用Arrays.toString()输出内部数组中的值。
思考

如果IntegerStack接口的实现类内部使用ArrayList来存储元素,怎么实现?测试代码需要进行什么修改?

输入样例

5
3
1 2 3
2

输出样例

1
2
3
3,false,3
[1, 2, 3, null, null]
3
2
1,false,1
[1, 2, 3, null, null]
import java.util.Arrays;
import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner input = new Scanner(System.in);
        int n = input.nextInt();
        ArrayIntegerStack a = new ArrayIntegerStack(n);
        int m = input.nextInt();
        while(m > 0){
            int item = input.nextInt();
            System.out.println(a.push(item));
            m--;
        }
        System.out.println(a.peek() + "," + a.empty() + "," + a.size());
        System.out.println(a);
        int x = input.nextInt();
        while(x > 0){
            System.out.println(a.pop());
            x--;
        }
        System.out.println(a.peek() + "," + a.empty() + "," + a.size());
        System.out.println(a);
    }
}
interface IntegerStack{
    public Integer push(Integer item);//如果item为null,则不入栈直接返回null。如果栈满,也返回null。如果插入成功,返回item。
    public Integer pop();   //出栈,如果为空,则返回null。出栈时只移动栈顶指针,相应位置不置为null
    public Integer peek();  //获得栈顶元素,如果为空,则返回null.
    public boolean empty(); //如果为空返回true
    public int size();      //返回栈中元素个数
}
class ArrayIntegerStack implements IntegerStack{
    Integer[] array;
    int top = 0;
    public ArrayIntegerStack(int n){
        array = new Integer[n];
        Arrays.fill(array, null);
    }

    public ArrayIntegerStack(){}

    @Override
    public String toString() {
        return Arrays.toString(array);
    }
    @Override
    public Integer push(Integer item) {
        if (item == null || array.length == top){
            return null;
        }
        array[top++] = item;
        return item;
    }

    @Override
    public Integer pop() {
        if (top == 0){
            return null;
        }
        return array[--top];
    }

    @Override
    public Integer peek() {
        if (top == 0){
            return null;
        }
        return array[top - 1];
    }

    @Override
    public boolean empty() {
        return top == 0;
    }

    @Override
    public int size() {
        return top;
    }
}
View Code

7-5 jmu-Java-03面向对象基础-05-覆盖

分数 5
作者 郑如滨
单位 集美大学

Java每个对象都继承自Object,都有equals、toString等方法。
现在需要定义PersonOverride类并覆盖其toStringequals方法。

1. 新建PersonOverride类

a. 属性:String nameint ageboolean gender,所有的变量必须为私有(private)。

b. 有参构造方法,参数为name, age, gender

c. 无参构造方法,使用this(name, age,gender)调用有参构造方法。参数值分别为"default",1,true

d.toString()方法返回格式为:name-age-gender

e. equals方法需比较name、age、gender,这三者内容都相同,才返回true.

2. main方法

2.1 输入n1,使用无参构造方法创建n1个对象,放入数组persons1。
2.2 输入n2,然后指定name age gender。每创建一个对象都使用equals方法比较该对象是否已经在数组中存在,如果不存在,才将该对象放入数组persons2。
2.3 输出persons1数组中的所有对象
2.4 输出persons2数组中的所有对象
2.5 输出persons2中实际包含的对象的数量
2.5 使用System.out.println(Arrays.toString(PersonOverride.class.getConstructors()));输出PersonOverride的所有构造方法。

提示:使用ArrayList代替数组大幅复简化代码,请尝试重构你的代码。

输入样例:

1
3
zhang 10 true
zhang 10 true
zhang 10 false

输出样例:

default-1-true
zhang-10-true
zhang-10-false
2
[public PersonOverride(), public PersonOverride(java.lang.String,int,boolean)]
import java.util.Arrays;
import java.util.Objects;
import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner input = new Scanner(System.in);
        int n1 = input.nextInt();
        PersonOverride[] personOverrides1 = new PersonOverride[n1];
        for(int i= 0;i<n1;i++)
            personOverrides1[i] = new PersonOverride();
        int n2 = input.nextInt();
        PersonOverride[] personOverrides2 = new PersonOverride[n2];
        int n=0;
        PersonOverride p;
        for (int i = 0; i < n2; i++) {
            p = new PersonOverride(input.next(), input.nextInt(), input.nextBoolean());
            int j = 0;
            while (j < n) {
                if (p.equals(personOverrides2[j]))
                    break;
                j++;
            }
            if (j >= n) {
                personOverrides2[n] = p;
                n++;
            }
        }
        for(int i=0;i<n1;i++)
        {
            System.out.println(personOverrides1[i].toString());
        }
        for (int i = 0; i < n; i++) {
            System.out.println(personOverrides2[i].toString());
        }
        System.out.println(n);
        System.out.println(Arrays.toString(PersonOverride.class.getConstructors()));
    }
}
class PersonOverride{
    private String name;
    private int age;
    private boolean gender;

    public PersonOverride() {
        this("default",1,true);
    }

    public PersonOverride(String name, int age, boolean gender) {
        this.name = name;
        this.age = age;
        this.gender = gender;
    }

    @Override
    public boolean equals(Object o) {
        if (this == o) return true;
        if (o == null || getClass() != o.getClass()) return false;
        PersonOverride that = (PersonOverride) o;
        return age == that.age && gender == that.gender && Objects.equals(name, that.name);
    }

    @Override
    public String toString() {
        return name+"-"+age+"-"+gender;
    }
}
View Code

采坑心得:

前两次作业没啥说的,没有啥坑。第三次作业坑就挺多的了,首先就是运行超时,主要原因是正则表达式部分写得过于冗长,简化过后便没有运行超时的结果了;其次就是权重等于1的问题了,有时权重之和确实等于1,但运行出来总会有些误差,于是乎把权重之和等于1的条件改成与1的差值小于1e-6,便过了一个测试点;最后就是审题问题了,他最后的输出与前两次的输出都不一样,因此需要注意改动。至于第14个测试点,一直没过,应该还是有些细节问题存在。

 

 

改进建议:

1、代码除了能否运行之外,还要注重代码本身的稳定性和健壮性,在相应题目的编码改进方面,我觉得可以考虑通过优化算法、增加注释、精简代码等方式来提高代码质量和可读性。另外,在提交源码之前,要仔细检查代码的逻辑和精度,确保答案的正确性。

2、在解题过程中我会由于对知识点的不熟悉导致无从下手,得反复翻看Java书本内容才能上手,尤其是7-2 课程成绩统计程序-3,在类与类之间属性与方法之间的相互调用会让我弄不清。

总结:

1、这三次作业包含的知识点很广泛,极大的补充了我的知识库,让我对java这门语言有了更深入的了解,也让我学会了更好的自主学习,自我学习。

2、要多花一点时间在学习java上,java中的已经定义的类是非常多的,仅仅是写题目的时候用一次只能有一个粗略映像,需要花其他时间去巩固。此外,在写题目时,自己需要更有耐心一点,不要急于求成,也不要不带脑子写代码,使得写出的代码不仅得分不高,质量还低。

posted @ 2023-06-28 14:26  雪泥鸡爪  阅读(78)  评论(0编辑  收藏  举报