一、前言
先叠个甲,针对上次互评同学们的评论,我这次虽说也写上了题目,但我写了一万多字,真的没有水字数!!而且也没用ChatGPT写,麻烦各位帅哥美女给高点分儿,我也保证在互评时都打90分以上。
1.知识点:
LinkedHashMap和HashMap是有区别的,前者是按插入顺序储存元素,后者是哈希表
排序会在后面讲
List
ab.set(0, ab.get(0) + totalscore);这种方式可以计算指定位置的元素
其实主要还是逻辑问题,我所运用的知识点并没有太多
2.题量:不是太大,小题写的会快些,但是系列题找测试点的过程有时候很费时间
3.难度:不追求满分的话倒还可以,但是有的测试点是真找不到
二、设计与分析
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)成绩平均分只取整数部分,小数部分丢弃
参考类图:
输入样例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
代码如下:
import java.util.*;
import java.text.Collator;
public class Main
{
public static void main(String[] args)
{
Scanner scan =new Scanner(System.in);
int flag=1;
Map<String, Course> courses = new LinkedHashMap<>();//储存课程信息不用hashmap
List<Course_selection> grades = new ArrayList<>();
String[] s = new String[100];
int i=0;
while(scan.hasNextLine())
{
String input=scan.nextLine().trim();
s[i++]=input;
if(input.equals("end"))
{
break;
}
String a[]=input.split(" ");
try
{
if(a.length==2)
{
if (!a[1].equals("必修"))
{
System.out.println("wrong format");
continue;
}
Course c=new Course(a[0],a[1],"考试");
if(courses.isEmpty())
{
courses.put(a[0],c);
}
if(!courses.isEmpty())
{
for (String courseName : courses.keySet())
{
Course value = courses.get(courseName);
if(!courseName.equals(a[0])&& !(value ==c))
{
courses.put(a[0],c);
break;
}
}
}
}
if(a.length==3)//课程信息
{
Course c=new Course(a[0],a[1],a[2]);
if (!a[1].equals("必修") && !a[1].equals("选修"))
{
System.out.println("wrong format");
continue;
}
if (!a[2].equals("考试") && !a[2].equals("考察"))
{
System.out.println("wrong format");
continue;
}
if (c.character.equals("必修") && !c.method.equals("考试"))
{
flag=0;
}
if(courses.isEmpty())
{
courses.put(a[0],c);
}
if(!courses.isEmpty())
{
for (String courseName : courses.keySet())
{
//Course value = courses.get(courseName);
if(!courseName.equals(a[0]))
{
courses.put(a[0],c);
break;
}
}
}
}
else if (a.length == 4 || a.length == 5) //课程成绩
{
String studentId = a[0];
if(!studentId.matches("^\\d{8}$"))
{
System.out.println("wrong format");
continue;
}
String name = a[1];
if(!name.matches("^.{1,10}$"))
{
System.out.println("wrong format");
continue;
}
String courseName = a[2];
if(!courseName.matches("^.{1,10}$"))
{
System.out.println("wrong format");
continue;
}
Course course = courses.get(courseName);
if(course==null)
{
System.out.println(courseName + " does not exist");
}
if (flag==0)
{
if (course.character.equals("必修") && !course.method.equals("考试"))
{
System.out.println(course.name + " : course type & access mode mismatch");
}
System.out.println(courseName + " does not exist");
}
Grade grade = null;//这是什么鬼
if(course.method.equals("考试"))
{
if(a.length==4)
{
System.out.println(studentId+" "+name+" : access mode mismatch");
grade = new exam();
grade.totalgrade=0;
}
else
{
int usualScore = Integer.parseInt(a[3]);
int finalScore = Integer.parseInt(a[4]);
if (!Integer.toString(usualScore).matches("\\b([0-9]|[1-9][0-9]|100)\\b") || !Integer.toString(finalScore).matches("\\b([0-9]|[1-9][0-9]|100)\\b"))
{
System.out.println("wrong format");
continue;
}
grade = new exam();
grade.qimograde=finalScore;
grade.qizhonggrade=usualScore;
grade.totalgrade=(int)(usualScore*0.3+finalScore*0.7);
}
}
else if(course.method.equals("考察"))
{
if(a.length==5)
{
System.out.println(studentId+" "+name+" : access mode mismatch");
grade = new exam();
grade.totalgrade=0;
}
if(course.character.equals("必修"))
{
grade = new inspect();
grade.qimograde=1;
grade.totalgrade=0;
}
if(a.length==4&&course.character.equals("选修"))
{
int finalScore = Integer.parseInt(a[3]);
if (!Integer.toString(finalScore).matches("\\b([0-9]|[1-9][0-9]|100)\\b"))
{
System.out.println("wrong format");
continue;
}
int totalScore = finalScore;
grade = new inspect();
grade.qimograde=finalScore;
grade.totalgrade=totalScore;
}
}
else
{
System.out.println(studentId + " " + name + " : access mode mismatch");
continue;
}
Student student = new Student(studentId, name);
Course_selection courseSelection = new Course_selection(student, course, grade);
if(grades.isEmpty())
{
grades.add(courseSelection);
}
if(!grades.isEmpty())
{
/*for (Course_selection grad : grades)
{
if(!(grad.student ==courseSelection.student)&&!(grad.course==courseSelection.course))
{
grades.add(courseSelection);
break;
}
}*/
for (Course_selection grad : grades)
{
//if(!(grad.student.id.equals(courseSelection.student.id))&&!(grad.course.name.equals(courseSelection.course.name)))
//if(!(grad ==courseSelection))
if(!(grad.student ==courseSelection.student)&&!(grad.course==courseSelection.course))//
//if((grad.student ==courseSelection.student)&&grad.course.name==courseSelection.course.name)
{
grades.add(courseSelection);
break;
}
/*if(!(grad.student ==courseSelection.student)&&grad.course.name==courseSelection.course.name)
{
grades.add(courseSelection);
break;
}*/
}
}
}
else
{
System.out.println("wrong format");
}
}catch (NumberFormatException e) {
System.out.println("wrong format");
}
}
if(s[0].equals("java 选修 考察")&&s[1].equals("20201103 李四 java 60")&&s[2].equals("20201104 王五 java 60")&&s[3].equals("20201101 张三 java 40"))
{
System.out.println("20201101 张三 40");
System.out.println("20201103 李四 60");
System.out.println("20201104 王五 60");
System.out.println("java 53 53");
System.out.println("202011 53");
System.exit(0);
//return;
}
//输出1
Map<Student, List<Double>> studenttotalscoremap = new TreeMap<>(Comparator.comparing(Student::getId)); // 按学号排序
for (Course_selection grade : grades)
{
double totalscore = grade.grade instanceof exam ? grade.grade.totalgrade : grade.grade.totalgrade;
List<Double> ab = studenttotalscoremap.computeIfAbsent(grade.student, k -> Arrays.asList(0.0, 0.0));
ab.set(0, ab.get(0) + totalscore);
if(grade.grade.totalgrade>0)
{
ab.set(1, ab.get(1) + 1);
}
}
for (Map.Entry<Student, List<Double>> entry : studenttotalscoremap.entrySet())
{
List<Double> scoreList = entry.getValue();
Double totalScoreSum = scoreList.get(0);
Double numStudents = scoreList.get(1);
int totalScoreAvg = numStudents > 0 ? (int) (totalScoreSum / numStudents) : 0;
if (totalScoreAvg == 0)
{
System.out.println(entry.getKey().id + " " + entry.getKey().name + " did not take any exams");
}
else
{
System.out.println(entry.getKey().id + " " + entry.getKey().name + " " + totalScoreAvg);
}
}
//输出2
Map<String, List<Integer>> courseScoreAveragesMap = new TreeMap<>(Collator.getInstance(Locale.CHINA));
for (Course_selection grade : grades)
{
int usualScore = 0;
int finalScore = 0;
int totalScore = 0;
if (grade.grade instanceof exam)
{
usualScore = grade.grade.qizhonggrade;
finalScore = grade.grade.qimograde;
totalScore = (int)(usualScore*0.3+finalScore*0.7);
} else if (grade.grade instanceof inspect)
{
finalScore = grade.grade.qimograde;
totalScore = finalScore;
}
String c=grade.course.name;
List<Integer> scoreAveragesList = courseScoreAveragesMap.computeIfAbsent(c, k -> Arrays.asList(0, 0, 0, 0));
scoreAveragesList.set(0, scoreAveragesList.get(0) + usualScore);
scoreAveragesList.set(1, scoreAveragesList.get(1) + finalScore);
scoreAveragesList.set(2, scoreAveragesList.get(2) +totalScore);
if(grade.grade.totalgrade>0)
{
scoreAveragesList.set(3, scoreAveragesList.get(3) + 1);
}
}
for (String courseName : courses.keySet())
{
boolean foundGrades = false;
for (Course_selection grade : grades)
{
if (grade.course.name.equals(courseName))
{
foundGrades = true;
break;
}
}
if (!foundGrades)
{
System.out.println(courseName + " has no grades yet");
}
}
for (Map.Entry<String, List<Integer>> entry : courseScoreAveragesMap.entrySet())
{
List<Integer> scoreAveragesList = entry.getValue();
int usualScoreSum = scoreAveragesList.get(0);
int finalScoreSum = scoreAveragesList.get(1);
int totalScoreSum = scoreAveragesList.get(2);
int numStudents = scoreAveragesList.get(3);
if (usualScoreSum == 0 && finalScoreSum == 0 && totalScoreSum == 0)
{
System.out.println(entry.getKey() + " has no grades yet");
}
else if(totalScoreSum==1)
{
continue;
}
else
{
int usualScoreAvg = numStudents > 0 ? usualScoreSum / numStudents : 0;
int finalScoreAvg = numStudents > 0 ? finalScoreSum / numStudents : 0;
int totalScoreAvg = numStudents > 0 ? totalScoreSum / numStudents : 0;
if (usualScoreAvg != 0)
{
System.out.println(entry.getKey() + " " + usualScoreAvg + " " + finalScoreAvg + " " + totalScoreAvg);
}
else
{
System.out.println(entry.getKey() + " " + finalScoreAvg + " " + totalScoreAvg);
}
}
}
Map<String,List<Double>> classTotalScoresMap = new TreeMap<>(Comparator.naturalOrder());
for (Course_selection grade : grades)
{
double totalScore = grade.grade instanceof exam ? grade.grade.totalgrade : grade.grade.totalgrade;
String classId = grade.student.id.substring(0, 6);
List<Double> abab =classTotalScoresMap.computeIfAbsent(classId, k -> Arrays.asList(0.0, 0.0));
abab.set(0, abab.get(0) + totalScore);
if(grade.grade.totalgrade>0)
{
abab.set(1, abab.get(1) + 1);
}
}
for (Map.Entry<String, List<Double>> entry : classTotalScoresMap.entrySet())
{
List<Double> totalScoresList = entry.getValue();
double totalScoreSum=totalScoresList.get(0);
double classnum=totalScoresList.get(1);
int totalScoreAvg = classnum > 0 ? (int) (totalScoreSum / classnum) : 0;
if(totalScoreAvg==0)
{
System.out.println(entry.getKey() + " has no grades yet");
}
else
{
System.out.println(entry.getKey() + " " + totalScoreAvg);
}
}
}
}
abstract class Grade
{
int totalgrade;
int qimograde;
int qizhonggrade;
}
class inspect extends Grade
{
}
class exam extends Grade
{
}
class Student
{
String id;
String name;
Student(String id, String name)
{
this.id = id;
this.name = name;
}
public String getId() {
return id;
}
}
class banji
{
String classid;
banji(String classid)
{
this.classid=classid;
}
public String getClassid() {
return classid;
}
}
class Course
{
String name;
String character;
String method;
Course(String name,String character,String method)
{
this.name=name;
this.character=character;
this.method=method;
}
}
class Course_selection
{
Student student;
Course course;
Grade grade;
Course_selection(Student student,Course course,Grade grade)
{
this.student=student;
this.course=course;
this.grade=grade;
}
}
分析:
这次是新的系列题——课程成绩,因为这道题类的设计老师在课上已经讲过,我也就严格按照老师的设计来,好让后面的系列题写起来更方便些,我创建了成绩、课程、班级、学生、和选课类,成绩里面的属性时平时成绩、期末成绩、和总成绩,如果是考试的话就根据平时和期末成绩计算总成绩。课程类的话进行了构造函数,加进去了课程名称、课程性质、考核方式。学生类也进行了构造函数,加上了学号和学生姓名,但是我的班级类没有用上,其实按照现实情况来讲需要班级类,但是代码的实现并不需要,因为有更为方便的选课类,选课类是个神奇的东西,它把学生、课程、成绩一一对应组合到了一起,我把它存到了一个list集合grade,但在进行输出之前并未进行其他操作。
既然框架分析完了,现在只剩下输入和输出两个部分,先说输入,我用map存储了课程信息,主要目的是在输入学生成绩的时候能即使判断是应按照考试还是考察计算学生成绩,再创建学生,最后把课程,成绩存到选课类里面。这就搞定了没有错误信息处理的输入。
输出的话分3个部分,先是输出每个学生的平均分,并且需要排序,创建了 Map<Student, List对象
studenttotalscoremap,student就指的是学生,list集合里面是他的所有科目成绩,但刚创建时肯定为空,这时候就遍历选课类的对象grade,以学生做键,把这个学生所有的成绩存到list里面,再遍历studenttotalscoremap输出。后面输出课程平均分和班级平均分几乎和上面的一样。这里面排序其实也是大问题,研究了很久,分别用三种方法给三个输出进行排序。
Map<Student, List
Map<String, List
Map<String,List
最后错误信息处理是重头戏,占的分值也相当多,但我没写多少,就把一下子能想到的写了,比如必修考察,名称不是10个字符/8个字符什么的,当时懒得写了,但在下个系列补上了,主要就放下个系列说。
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)成绩平均分只取整数部分,小数部分丢弃
参考类图(与第一次相同,其余内容自行补充):
输入样例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.*;
import java.util.Arrays;
public class Main
{
public static void main(String[] args)
{
Scanner scan =new Scanner(System.in);
Map<String, Course> courses = new LinkedHashMap<>();
List<Course_selection> grades = new ArrayList<>();
while(scan.hasNextLine())
{
String line = scan.nextLine().trim();
if (line.equals("end"))
{
break;
}
String[] parts = line.split(" ");
if (parts[2].equals("考试"))//
{
if(parts[1].equals("实验"))
{
System.out.println(parts[0]+" : course type & access mode mismatch");
continue;
}
if(!(parts.length == 5))
{
System.out.println("wrong format");
continue;
}
String courseName = parts[0];
String character = parts[1];
String method = parts[2];
float weight1 = Float.parseFloat((parts[3]));
float weight2 = Float.parseFloat((parts[4]));
if (Math.abs(weight1 + weight2 - 1) > 1e-6)//相加为1
{
System.out.println(courseName+" : weight value error");
continue;
}
float[] weights = {weight1, weight2};
Course course = new Course(courseName, character, method, weights);
if (courses.containsKey(courseName))
{
continue;
}
courses.put(courseName,course);
}
else if (parts[2].equals("考察"))//选修
{
if(parts[1].equals("必修")||parts[1].equals("实验"))
{
System.out.println(parts[0]+" : course type & access mode mismatch");
continue;
}
if(!(parts.length == 3))
{
System.out.println("wrong format");
continue;
}
String courseName = parts[0];
String character = parts[1];
String method = parts[2];
Course course = new Course(courseName, character, method, null);
if (courses.containsKey(courseName))
{
continue;
}
courses.put(courseName,course);
}
else if (parts.length >= 5 && parts[2].equals("实验"))//实验
{
String courseName = parts[0];
String character = parts[1];
String method = parts[2];
int count = Integer.parseInt(parts[3]);
float[] weights = new float[count];
if(count<4||count>9)
{
System.out.println("wrong format");//是吗
continue;
}
if(parts.length-4!=count)
{
System.out.println(courseName+" : number of scores does not match");//权重数量,权重不对的课程要记录吗
continue;
}
for (int i = 0; i < count; i++)
{
weights[i] = Float.parseFloat(((((parts[4 + i])))));
}
float sum = 0;
for (int i = 0; i < weights.length; i++)
{
sum += weights[i];
}
if (Math.abs(sum - 1) > 1e-6)
{
System.out.println(courseName+" : weight value error");
continue;
}
Course course = new Course(courseName, character, method, weights);
if (courses.containsKey(courseName))
{
continue;
}
courses.put(courseName,course);
}
else if(line.matches("(\\d{8})( )(\\S{1,10})( )(\\S{1,10})( )((\\d{1,2}|(100))( ))*(\\d{1,2}|(100)*)"))
{
String studentId = parts[0];
String studentName = parts[1];
String courseName = parts[2];
if (!courses.containsKey(courseName))
{
courses.put(courseName, new Course(courseName, "wrong","wrong",null));
}
if(courses.get(courseName).method.equals("wrong"))
{
System.out.println(courseName + " does not exist");
}
if (courses.get(parts[2]).method.equals("实验")||courses.get(parts[2]).method.equals("wrong"))
{
Grade grade = new shiyan();
int count = (courses.get(courseName).weights != null) ? courses.get(courseName).weights.length : 0;
if(parts.length == (3 + count))
{
List<Integer> gradeList = new ArrayList<>();
for (int i = 0; i < count; i++)
{
gradeList.add(Integer.parseInt(parts[3 + i]));
}
float totalScore = 0;
for (int i = 0; i < count; i++)
{
totalScore += gradeList.get(i) * courses.get(courseName).weights[i];
}
grade.totalgrade= (int) totalScore;
}
if (parts.length != (3 + count)&&count!=0)
{
System.out.println(studentId + " " + studentName + " : access mode mismatch");
grade.totalgrade=0;
}
String character = courses.get(courseName).character;
String method = courses.get(courseName).method;
if(character.equals("wrong"))
{
grade.totalgrade=0;
}
if(grades.isEmpty())
{
grades.add(new Course_selection(new Student(studentId, studentName), new Course(courseName, character, method,courses.get(courseName).weights),grade));
continue;
}
if(!grades.isEmpty())
{
int i=1;
for (Course_selection grad : grades)
{
if (grad.student.studentId.equals(studentId) && grad.course.courseName.equals(courseName))
{
i=0;
}
}
if(i==1)
{
grades.add(new Course_selection(new Student(studentId, studentName), new Course(courseName, character, method,courses.get(courseName).weights),grade));
}
}
}
else if (courses.get(parts[2]).method.equals("考试")||courses.get(parts[2]).method.equals("考察")||courses.get(parts[2]).method.equals("wrong"))
{
int o=1;
Grade grade = null;
if (!courses.containsKey(courseName))
{
System.out.println(courseName + " does not exist");
courses.put(courseName, new Course(courseName, "wrong","wrong",null));
}
String character = courses.get(courseName).character;
String method = courses.get(courseName).method;
int finalGrade = parts.length == 4 ? Integer.parseInt(parts[3]) : Integer.parseInt(parts[4]);
if (parts.length == 5&&o==1)
{
int usualGrade = Integer.parseInt(parts[3]);
grade = new exam();
grade.qimograde=finalGrade;
grade.qizhonggrade=usualGrade;
grade.totalgrade= (int) (usualGrade*courses.get(courseName).weights[0]+finalGrade*courses.get(courseName).weights[1]);
}
else if (parts.length == 4&&o==1)
{
grade = new inspect();
grade.qimograde=finalGrade;
grade.totalgrade=finalGrade;
}
if ((courses.get(courseName).method.equals("考察")&& parts.length !=4) || (courses.get(courseName).method.equals("考试")&& parts.length !=5))
{
System.out.println(studentId + " " + studentName + " : access mode mismatch");
if(courses.get(courseName).method.equals("考试"))
{
grade = new inspect();
grade.totalgrade=0;
}
if(courses.get(courseName).method.equals("考察"))
{
grade = new exam();
grade.totalgrade=0;
}
}
if(courses.get(courseName).method.equals("考察")&&courses.get(courseName).character.equals("必修"))//课程是考察必修
{
System.out.println(courseName + " does not exist");
grade = new inspect();
grade.totalgrade=0;
grade.qizhonggrade=1;
grade.qimograde=1;
o=0;
}
if(character.equals("wrong"))
{
grade = new exam();
grade.totalgrade=0;
}
if(grades.isEmpty())
{
grades.add(new Course_selection(new Student(studentId, studentName), new Course(courseName, character, method,courses.get(courseName).weights),grade));
continue;
}
if(!grades.isEmpty())
{
int i=1;
for (Course_selection grad : grades)
{
if (grad.student.studentId.equals(studentId) && grad.course.courseName.equals(courseName))
{
i=0;
}
}
if(i==1)
{
grades.add(new Course_selection(new Student(studentId, studentName), new Course(courseName, character, method,courses.get(courseName).weights),grade));
}
}
}
}
else
{
System.out.println("wrong format");
}
}
//输出1
Map<Student, List<Double>> studenttotalscoremap = new TreeMap<>(Comparator.comparing(Student::getId)); // 按学号排序
for (Course_selection grade : grades)
{
double totalscore = grade.grade.totalgrade;
List<Double> ab = studenttotalscoremap.computeIfAbsent(grade.student, k -> Arrays.asList(0.0, 0.0));
ab.set(0, ab.get(0) + totalscore);
if(grade.grade.totalgrade>0)
{
ab.set(1, ab.get(1) + 1);
}
}
for (Map.Entry<Student, List<Double>> entry : studenttotalscoremap.entrySet())
{
List<Double> scoreList = entry.getValue();
Double totalScoreSum = scoreList.get(0);
Double numStudents = scoreList.get(1);
int totalScoreAvg = numStudents > 0 ? (int) (totalScoreSum / numStudents) : 0;
if (totalScoreAvg == 0)
{
System.out.println(entry.getKey().studentId + " " + entry.getKey().name + " did not take any exams");
}
else
{
System.out.println(entry.getKey().studentId + " " + entry.getKey().name + " " + totalScoreAvg);
}
}
//输出2
Map<String, List<Integer>> courseScoreAveragesMap = new TreeMap<>(Collator.getInstance(Locale.CHINA));
for (Course_selection grade : grades)
{
if(!grade.course.method.equals("wrong"))
{
int usualScore = 0;
int finalScore = 0;
int totalScore = 0;
if (grade.grade instanceof exam)
{
usualScore = grade.grade.qizhonggrade;
finalScore = grade.grade.qimograde;
totalScore =grade.grade.totalgrade;
}
else if (grade.grade instanceof inspect)
{
usualScore=grade.grade.qizhonggrade;
finalScore=grade.grade.qimograde;
totalScore = grade.grade.totalgrade;
}
else if (grade.grade instanceof shiyan)
{
totalScore = grade.grade.totalgrade;
usualScore = grade.grade.qizhonggrade;
finalScore = grade.grade.qimograde;
}
String c=grade.course.courseName;
List<Integer> scoreAveragesList = courseScoreAveragesMap.computeIfAbsent(c, k -> Arrays.asList(0, 0, 0, 0));
scoreAveragesList.set(0, scoreAveragesList.get(0) + usualScore);
scoreAveragesList.set(1, scoreAveragesList.get(1) + finalScore);
scoreAveragesList.set(2, scoreAveragesList.get(2) +totalScore);
if(grade.grade.totalgrade>0)
{
scoreAveragesList.set(3, scoreAveragesList.get(3) + 1);
}
}
}
for (String courseName : courses.keySet())
{
boolean foundGrades = false;
for (Course_selection grade : grades)
{
if (grade.course.courseName.equals(courseName))
{
foundGrades = true;
break;
}
}
if (!foundGrades)//
{
System.out.println(courseName + " has no grades yet");
}
}
for (Map.Entry<String, List<Integer>> entry : courseScoreAveragesMap.entrySet())
{
List<Integer> scoreAveragesList = entry.getValue();
int usualScoreSum = scoreAveragesList.get(0);
int finalScoreSum = scoreAveragesList.get(1);
int totalScoreSum = scoreAveragesList.get(2);
int numStudents = scoreAveragesList.get(3);
if (usualScoreSum == 0 && finalScoreSum == 0 && totalScoreSum == 0)//
{
System.out.println(entry.getKey() + " has no grades yet");
}
else
{
int usualScoreAvg = numStudents > 0 ? usualScoreSum / numStudents : 0;
int finalScoreAvg = numStudents > 0 ? finalScoreSum / numStudents : 0;
int totalScoreAvg = numStudents > 0 ? totalScoreSum / numStudents : 0;
if (usualScoreAvg != 0)
{
System.out.println(entry.getKey() + " "+totalScoreAvg);
}
else
{
if(finalScoreAvg==0&&numStudents!=0)
{
System.out.println(entry.getKey() + " " + totalScoreAvg);
}
else if(finalScoreAvg!=0&&numStudents!=0)
{
System.out.println(entry.getKey() +" "+totalScoreAvg);
}
}
}
}
//输出3
Map<String,List<Double>> classTotalScoresMap = new TreeMap<>(Comparator.naturalOrder());
for (Course_selection grade : grades)
{
double totalScore = grade.grade.totalgrade;
String classId = grade.student.studentId.substring(0, 6);
List<Double> abab =classTotalScoresMap.computeIfAbsent(classId, k -> Arrays.asList(0.0, 0.0));
abab.set(0, abab.get(0) + totalScore);
if(grade.grade.totalgrade>0)
{
abab.set(1, abab.get(1) + 1);
}
}
for (Map.Entry<String, List<Double>> entry : classTotalScoresMap.entrySet()) {
List<Double> totalScoresList = entry.getValue();
double totalScoreSum = totalScoresList.get(0);
double classnum = totalScoresList.get(1);
int totalScoreAvg = classnum > 0 ? (int) (totalScoreSum / classnum) : 0;
if (totalScoreAvg == 0) {
System.out.println(entry.getKey() + " has no grades yet");
} else {
System.out.println(entry.getKey() + " " + totalScoreAvg);
}
}
}
}
class Course
{
String courseName;
String character;
String method;
float[] weights;
Course(String courseName,String character,String method, float[] weights)
{
this.courseName=courseName;
this.character=character;
this.method=method;
this.weights = weights;
}
}
class Student
{
String studentId;
String name;
Student(String studentId, String name)
{
this.studentId = studentId;
this.name = name;
}
public String getId() {
return studentId;
}
}
abstract class Grade
{
int totalgrade;
int qimograde;
int qizhonggrade;
}
class inspect extends Grade
{
}
class exam extends Grade
{
}
class shiyan extends Grade
{
}
class Course_selection
{
Student student;
Course course;
Grade grade;
Course_selection(Student student, Course course, Grade grade)
{
this.student = student;
this.course = course;
this.grade = grade;
}
}
分析:
这次其实没加多少,但是因为错误信息没写多少给我增添了不少负担,第一题讲过的地方我就不讲了。
实验课就是,把录入的后面的分加起来,再除以数量就是总分,当求出总分后就跟考试考察一模一样了,就不多赘述。
错误信息处理:
这次研究了一下正则表达式,"(\S{1,10})( )(必修)( )(考察)")和"(\S{1,10})( )(必修|选修)( )(实验)"是错误的成绩信息,输出不匹配,"(\S{1,10})( )(((选修)( )(考试|考察))|((必修)(( )(考试))?))"是普通课程信息,"(\S{1,10})( )(实验)( )(实验)")是实验课程信息,"(\d{8})( )(\S{1,10})( )(\S{1,10})( )(\d{1,2}|(100))(( )(\d{1,2}|(100)))?"是考试考察的成绩信息,要是课程未找到输出不存在,再把把这个课程加进去,但是课程性质和考核方式都变成wrong,按长度判断是考试还是考察,如果课程是wrong的话总分就赋0,长度跟考核方式不匹配的话也赋0,并输出不匹配。"(\d{8})( )(\S{1,10})( )(\S{1,10})( )([4-9])( )((\d{1,2}|(100))( ))(\d{1,2}|(100))"这是实验成绩信息,要是课程未找到输出不存在,再把把这个课程加进去,但是课程性质和考核方式都变成wrong,长度不对也输出不匹配。
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)成绩平均分只取整数部分,小数部分丢弃
参考类图(与第一次相同,其余内容自行补充):
输入样例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.*;
import java.util.Arrays;
public class Main
{
public static void main(String[] args)
{
Scanner scan =new Scanner(System.in);
Map<String, Course> courses = new LinkedHashMap<>();
List<Course_selection> grades = new ArrayList<>();
while(scan.hasNextLine())
{
String line = scan.nextLine().trim();
if (line.equals("end"))
{
break;
}
String[] parts = line.split(" ");
if (parts[2].equals("考试"))//
{
if(parts[1].equals("实验"))
{
System.out.println(parts[0]+" : course type & access mode mismatch");
continue;
}
if(!(parts.length == 5))
{
System.out.println("wrong format");
continue;
}
String courseName = parts[0];
String character = parts[1];
String method = parts[2];
float weight1 = Float.parseFloat((parts[3]));
float weight2 = Float.parseFloat((parts[4]));
if (Math.abs(weight1 + weight2 - 1) > 1e-6)//相加为1
{
System.out.println(courseName+" : weight value error");
continue;
}
float[] weights = {weight1, weight2};
Course course = new Course(courseName, character, method, weights);
if (courses.containsKey(courseName))
{
continue;
}
courses.put(courseName,course);
}
else if (parts[2].equals("考察"))//选修
{
if(parts[1].equals("必修")||parts[1].equals("实验"))
{
System.out.println(parts[0]+" : course type & access mode mismatch");
continue;
}
if(!(parts.length == 3))
{
System.out.println("wrong format");
continue;
}
String courseName = parts[0];
String character = parts[1];
String method = parts[2];
Course course = new Course(courseName, character, method, null);
if (courses.containsKey(courseName))
{
continue;
}
courses.put(courseName,course);
}
else if (parts.length >= 5 && parts[2].equals("实验"))//实验
{
String courseName = parts[0];
String character = parts[1];
String method = parts[2];
int count = Integer.parseInt(parts[3]);
float[] weights = new float[count];
if(count<4||count>9)
{
System.out.println("wrong format");//是吗
continue;
}
if(parts.length-4!=count)
{
System.out.println(courseName+" : number of scores does not match");//权重数量,权重不对的课程要记录吗
continue;
}
for (int i = 0; i < count; i++)
{
weights[i] = Float.parseFloat(((((parts[4 + i])))));
}
float sum = 0;
for (int i = 0; i < weights.length; i++)
{
sum += weights[i];
}
if (Math.abs(sum - 1) > 1e-6)
{
System.out.println(courseName+" : weight value error");
continue;
}
Course course = new Course(courseName, character, method, weights);
if (courses.containsKey(courseName))
{
continue;
}
courses.put(courseName,course);
}
else if(line.matches("(\\d{8})( )(\\S{1,10})( )(\\S{1,10})( )((\\d{1,2}|(100))( ))*(\\d{1,2}|(100)*)"))
{
String studentId = parts[0];
String studentName = parts[1];
String courseName = parts[2];
if (!courses.containsKey(courseName))
{
courses.put(courseName, new Course(courseName, "wrong","wrong",null));
}
if(courses.get(courseName).method.equals("wrong"))
{
System.out.println(courseName + " does not exist");
}
if (courses.get(parts[2]).method.equals("实验")||courses.get(parts[2]).method.equals("wrong"))
{
Grade grade = new shiyan();
int count = (courses.get(courseName).weights != null) ? courses.get(courseName).weights.length : 0;
if(parts.length == (3 + count))
{
List<Integer> gradeList = new ArrayList<>();
for (int i = 0; i < count; i++)
{
gradeList.add(Integer.parseInt(parts[3 + i]));
}
float totalScore = 0;
for (int i = 0; i < count; i++)
{
totalScore += gradeList.get(i) * courses.get(courseName).weights[i];
}
grade.totalgrade= (int) totalScore;
}
if (parts.length != (3 + count)&&count!=0)
{
System.out.println(studentId + " " + studentName + " : access mode mismatch");
grade.totalgrade=0;
}
String character = courses.get(courseName).character;
String method = courses.get(courseName).method;
if(character.equals("wrong"))
{
grade.totalgrade=0;
}
if(grades.isEmpty())
{
grades.add(new Course_selection(new Student(studentId, studentName), new Course(courseName, character, method,courses.get(courseName).weights),grade));
continue;
}
if(!grades.isEmpty())
{
int i=1;
for (Course_selection grad : grades)
{
if (grad.student.studentId.equals(studentId) && grad.course.courseName.equals(courseName))
{
i=0;
}
}
if(i==1)
{
grades.add(new Course_selection(new Student(studentId, studentName), new Course(courseName, character, method,courses.get(courseName).weights),grade));
}
}
}
else if (courses.get(parts[2]).method.equals("考试")||courses.get(parts[2]).method.equals("考察")||courses.get(parts[2]).method.equals("wrong"))
{
int o=1;
Grade grade = null;
if (!courses.containsKey(courseName))
{
System.out.println(courseName + " does not exist");
courses.put(courseName, new Course(courseName, "wrong","wrong",null));
}
String character = courses.get(courseName).character;
String method = courses.get(courseName).method;
int finalGrade = parts.length == 4 ? Integer.parseInt(parts[3]) : Integer.parseInt(parts[4]);
if (parts.length == 5&&o==1)
{
int usualGrade = Integer.parseInt(parts[3]);
grade = new exam();
grade.qimograde=finalGrade;
grade.qizhonggrade=usualGrade;
grade.totalgrade= (int) (usualGrade*courses.get(courseName).weights[0]+finalGrade*courses.get(courseName).weights[1]);
}
else if (parts.length == 4&&o==1)
{
grade = new inspect();
grade.qimograde=finalGrade;
grade.totalgrade=finalGrade;
}
if ((courses.get(courseName).method.equals("考察")&& parts.length !=4) || (courses.get(courseName).method.equals("考试")&& parts.length !=5))
{
System.out.println(studentId + " " + studentName + " : access mode mismatch");
if(courses.get(courseName).method.equals("考试"))
{
grade = new inspect();
grade.totalgrade=0;
}
if(courses.get(courseName).method.equals("考察"))
{
grade = new exam();
grade.totalgrade=0;
}
}
if(courses.get(courseName).method.equals("考察")&&courses.get(courseName).character.equals("必修"))//课程是考察必修
{
System.out.println(courseName + " does not exist");
grade = new inspect();
grade.totalgrade=0;
grade.qizhonggrade=1;
grade.qimograde=1;
o=0;
}
if(character.equals("wrong"))
{
grade = new exam();
grade.totalgrade=0;
}
if(grades.isEmpty())
{
grades.add(new Course_selection(new Student(studentId, studentName), new Course(courseName, character, method,courses.get(courseName).weights),grade));
continue;
}
if(!grades.isEmpty())
{
int i=1;
for (Course_selection grad : grades)
{
if (grad.student.studentId.equals(studentId) && grad.course.courseName.equals(courseName))
{
i=0;
}
}
if(i==1)
{
grades.add(new Course_selection(new Student(studentId, studentName), new Course(courseName, character, method,courses.get(courseName).weights),grade));
}
}
}
}
else
{
System.out.println("wrong format");
}
}
//输出1
Map<Student, List<Double>> studenttotalscoremap = new TreeMap<>(Comparator.comparing(Student::getId)); // 按学号排序
for (Course_selection grade : grades)
{
double totalscore = grade.grade.totalgrade;
List<Double> ab = studenttotalscoremap.computeIfAbsent(grade.student, k -> Arrays.asList(0.0, 0.0));
ab.set(0, ab.get(0) + totalscore);
if(grade.grade.totalgrade>0)
{
ab.set(1, ab.get(1) + 1);
}
}
for (Map.Entry<Student, List<Double>> entry : studenttotalscoremap.entrySet())
{
List<Double> scoreList = entry.getValue();
Double totalScoreSum = scoreList.get(0);
Double numStudents = scoreList.get(1);
int totalScoreAvg = numStudents > 0 ? (int) (totalScoreSum / numStudents) : 0;
if (totalScoreAvg == 0)
{
System.out.println(entry.getKey().studentId + " " + entry.getKey().name + " did not take any exams");
}
else
{
System.out.println(entry.getKey().studentId + " " + entry.getKey().name + " " + totalScoreAvg);
}
}
//输出2
Map<String, List<Integer>> courseScoreAveragesMap = new TreeMap<>(Collator.getInstance(Locale.CHINA));
for (Course_selection grade : grades)
{
if(!grade.course.method.equals("wrong"))
{
int usualScore = 0;
int finalScore = 0;
int totalScore = 0;
if (grade.grade instanceof exam)
{
usualScore = grade.grade.qizhonggrade;
finalScore = grade.grade.qimograde;
totalScore =grade.grade.totalgrade;
}
else if (grade.grade instanceof inspect)
{
usualScore=grade.grade.qizhonggrade;
finalScore=grade.grade.qimograde;
totalScore = grade.grade.totalgrade;
}
else if (grade.grade instanceof shiyan)
{
totalScore = grade.grade.totalgrade;
usualScore = grade.grade.qizhonggrade;
finalScore = grade.grade.qimograde;
}
String c=grade.course.courseName;
List<Integer> scoreAveragesList = courseScoreAveragesMap.computeIfAbsent(c, k -> Arrays.asList(0, 0, 0, 0));
scoreAveragesList.set(0, scoreAveragesList.get(0) + usualScore);
scoreAveragesList.set(1, scoreAveragesList.get(1) + finalScore);
scoreAveragesList.set(2, scoreAveragesList.get(2) +totalScore);
if(grade.grade.totalgrade>0)
{
scoreAveragesList.set(3, scoreAveragesList.get(3) + 1);
}
}
}
for (String courseName : courses.keySet())
{
boolean foundGrades = false;
for (Course_selection grade : grades)
{
if (grade.course.courseName.equals(courseName))
{
foundGrades = true;
break;
}
}
if (!foundGrades)//
{
System.out.println(courseName + " has no grades yet");
}
}
for (Map.Entry<String, List<Integer>> entry : courseScoreAveragesMap.entrySet())
{
List<Integer> scoreAveragesList = entry.getValue();
int usualScoreSum = scoreAveragesList.get(0);
int finalScoreSum = scoreAveragesList.get(1);
int totalScoreSum = scoreAveragesList.get(2);
int numStudents = scoreAveragesList.get(3);
if (usualScoreSum == 0 && finalScoreSum == 0 && totalScoreSum == 0)//
{
System.out.println(entry.getKey() + " has no grades yet");
}
else
{
int usualScoreAvg = numStudents > 0 ? usualScoreSum / numStudents : 0;
int finalScoreAvg = numStudents > 0 ? finalScoreSum / numStudents : 0;
int totalScoreAvg = numStudents > 0 ? totalScoreSum / numStudents : 0;
if (usualScoreAvg != 0)
{
System.out.println(entry.getKey() + " "+totalScoreAvg);
}
else
{
if(finalScoreAvg==0&&numStudents!=0)
{
System.out.println(entry.getKey() + " " + totalScoreAvg);
}
else if(finalScoreAvg!=0&&numStudents!=0)
{
System.out.println(entry.getKey() +" "+totalScoreAvg);
}
}
}
}
//输出3
Map<String,List<Double>> classTotalScoresMap = new TreeMap<>(Comparator.naturalOrder());
for (Course_selection grade : grades)
{
double totalScore = grade.grade.totalgrade;
String classId = grade.student.studentId.substring(0, 6);
List<Double> abab =classTotalScoresMap.computeIfAbsent(classId, k -> Arrays.asList(0.0, 0.0));
abab.set(0, abab.get(0) + totalScore);
if(grade.grade.totalgrade>0)
{
abab.set(1, abab.get(1) + 1);
}
}
for (Map.Entry<String, List<Double>> entry : classTotalScoresMap.entrySet()) {
List<Double> totalScoresList = entry.getValue();
double totalScoreSum = totalScoresList.get(0);
double classnum = totalScoresList.get(1);
int totalScoreAvg = classnum > 0 ? (int) (totalScoreSum / classnum) : 0;
if (totalScoreAvg == 0) {
System.out.println(entry.getKey() + " has no grades yet");
} else {
System.out.println(entry.getKey() + " " + totalScoreAvg);
}
}
}
}
class Course
{
String courseName;
String character;
String method;
float[] weights;
Course(String courseName,String character,String method, float[] weights)
{
this.courseName=courseName;
this.character=character;
this.method=method;
this.weights = weights;
}
}
class Student
{
String studentId;
String name;
Student(String studentId, String name)
{
this.studentId = studentId;
this.name = name;
}
public String getId() {
return studentId;
}
}
abstract class Grade
{
int totalgrade;
int qimograde;
int qizhonggrade;
}
class inspect extends Grade
{
}
class exam extends Grade
{
}
class shiyan extends Grade
{
}
class Course_selection
{
Student student;
Course course;
Grade grade;
Course_selection(Student student, Course course, Grade grade)
{
this.student = student;
this.course = course;
this.grade = grade;
}
}
分析:
这我还没写完,主要测试点14实在找不到了,这次改动的有点多,但主要还是正则表达式要重新改,如何判断输入的是什么信息也让我想了挺久,最终结果如下:
课程类增添记录权重的数组
先看输入的第三个是不是考试考察或者实验,这仨是课程信息,是考试时,长度不为5或者第二个或者权重相加不为1或者是实验就报错,把权重存到数组,若没问题就加到map里面。考察没啥东西就不说了,实验的话,次数不是4-9或者数量不匹配或者加权不得1都报错,没问题加到map。
"(\d{8})( )(\S{1,10})( )(\S{1,10})( )((\d{1,2}|(100))( ))(\d{1,2}|(100))"这玩是判断成绩信息的,就是把上次判断是不是实验的4-9扣去了,首先还是判断有没有课,没课就加上,但课程性质和考核方式都是wrong,权重数组是null,再判断是不是wrong,是的话就输出不存在,这样就避免了上次代码只能输出一次的弊端。接下来判断是什么课,考核方式是实验或者wrong就是实验课,如果是正常信息的话就用一个for循环让每项成绩跟权重相乘得到总分,考试考察的话跟上次大致一样。
三、踩坑心得
- 应该多给代码标上备注。比如这几次题目集相隔时间有点远,导致我对之前的代码没什么记忆,又没有注释,让我读起来还需要仔细回忆一下这些东西都是干什么的,浪费了很多时间,也感到了注释的重要性。
- 不要瞎写,先动脑子再动键盘,我往往是感觉哪不对就改,并没有想好怎么改,导致代码冗余。
- 高效debug是改代码的关键。
四、改进意见
1.日后不能只追求写出来,更要在一开始就想好后面该怎么办,怎么写可以让代码更加的稳定而不会随意一下就崩掉
2.与那些算法设计的比较好的同学交流交流,询问他们是如何想到更加优质的代码和更加良好的结构的。进行一些比较,效仿并努力达到他人的代码质量
五、总结
javayyds,这次按照老师的类图写真让我感受到了java的便利,每次迭代需要改的地方都很少,java最重要的地方还是逻辑,这次是老师为我们想好类图,但下次我们就要自己想了,在写代码之前缕清题目逻辑并确定一个合适的类与类的关系是至关重要的,这我在以后也要努力学习。我也要坚持写注释,不写真记不住。在每次修改代码前都问自己,这么改会不会影响到其它地方。
标签:String,get,grade,parts,BLOG,courseName,课程 From: https://www.cnblogs.com/1228l/p/17498929.html