一、前言
先叠个甲,针对上次互评同学们的评论,我这次虽说也写上了题目,但我写了一万多字,真的没有水字数!!而且也没用ChatGPT写,麻烦各位帅哥美女给高点分儿,我也保证在互评时都打90分以上。
1.知识点:
LinkedHashMap和HashMap是有区别的,前者是按插入顺序储存元素,后者是哈希表
排序会在后面讲
List ab = studenttotalscoremap.computeIfAbsent(grade.student, k -> Arrays.asList(0.0, 0.0));
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 =