BLOG-3 PTA7-8次作业及期末考试总结
前言
这三次的大作业相较于菜单系列并没有涉及新的主要知识点。
在这个学期里,我深入学习了Java,了解了三大基本特征——封装、继承和多态。
随后,我接触到了类的设计,以及类设计的七大原则——开闭原则:可以在不修改原有模块的情况下便修扩展其功能。这一点极大的方便了程序员编程的过程。使得他们可以仅仅是添加一段代码便可以添加一盒功能,而不需要对主模块进行修改。、单一职责原则:对于一个类,应该只能有一个能够引起它变化的原因。也就是说这可以使代码更见简洁,像数学中的一个自变量只对应一个因变量一样,适合人类思想、依赖倒置原则:高层不应该依赖于底层的模块、里氏替换原则:需要在不知道子类的情况下即可调用父类、接口隔离原则:不能强迫用户去依赖他们不使用的接口。也就是说接口之类的要尽量的缩小,不可以太过冗杂,接口中的方法要尽量小、迪米特法则:每一个软件都尽可能地与其他软件减少关系。可以使各模块之间的联系减少,从而使每个模块都更加地独立 以及组合/聚合复用原则:要尽量不使用类继承。这些实际使用起来是非常实用的
课程成绩统计程序-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)成绩平均分只取整数部分,小数部分丢弃
参考类图(与第一次相同,其余内容自行补充):

输入样例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
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.text.Collator;
import java.util.*;
import java.util.stream.Collectors;
public class Main {
public static void main(String[] args) throws IOException {
BufferedReader in = new BufferedReader(new InputStreamReader(System.in));
MessageGetAndPrint messageGetAndPrint = new MessageGetAndPrint();
messageGetAndPrint.print = new Print();
for(;;){
String message = in.readLine();
if(message.equals("end")) {
messageGetAndPrint.print.personPrint(messageGetAndPrint.students , messageGetAndPrint.courseSelections);
messageGetAndPrint.print.coursePrint(messageGetAndPrint.courses , messageGetAndPrint.courseSelections);
messageGetAndPrint.print.classPrint(messageGetAndPrint.classes , messageGetAndPrint.courseSelections);
break;
}
messageGetAndPrint.getMessage(message);
}
}
}
class Class {
private String classNum;
HashMap<String , Student> students;
Class(String classNum) {
setClassNum(classNum);
}
public void setClassNum(String classNum) {
this.classNum = classNum;
}
public String getClassNum() {
return classNum;
}
public void addStudent(Student student) {
students.put(student.getStudentNum() , student);
}
public void deleteStudent(String studentNum) {
students.remove(studentNum);
}
}
class Student {
private String name;
private String studentNum;
Student(String name , String studentNum) {
setName(name);
setStudentNum(studentNum);
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getStudentNum() {
return studentNum;
}
public void setStudentNum(String studentNum) {
this.studentNum = studentNum;
}
}
class Course {
private String className;
private int classQuality;
private int assessmentMethodology;
Course(String className , int classQuality , int assessmentMethodology) {
setClassName(className);
setClassQuality(classQuality);
setAssessmentMethodology(assessmentMethodology);
}
public String getClassName() {
return className;
}
public void setClassName(String className) {
this.className = className;
}
public int getClassQuality() {
return classQuality;
}
public void setClassQuality(int classQuality) {
this.classQuality = classQuality;
}
public int getAssessmentMethodology() {
return assessmentMethodology;
}
public void setAssessmentMethodology(int assessmentMethodology) {
this.assessmentMethodology = assessmentMethodology;
}
}
class CourseSelection {
Student student;
Course course;
Grade grade;
}
abstract class Grade {
int allGrade;
abstract void getAllGrade();
}
class GradeA extends Grade {
private int finalGrade;
private int usualGrade;
GradeA(int finalGrade , int usualGrade) {
setFinalGrade(finalGrade);
setUsualGrade(usualGrade);
}
public void setFinalGrade(int finalGrade) {
this.finalGrade = finalGrade;
}
public int getFinalGrade() {
return finalGrade;
}
public void setUsualGrade(int usualGrade) {
this.usualGrade = usualGrade;
}
public int getUsualGrade() {
return usualGrade;
}
@Override
void getAllGrade() {
allGrade = (int) (finalGrade*0.7+usualGrade*0.3);
}
}
class GradeB extends Grade {
private int finalGrade;
GradeB(int finalGrade) {
setFinalGrade(finalGrade);
}
public void setFinalGrade(int finalGrade) {
this.finalGrade = finalGrade;
}
public int getFinalGrade() {
return finalGrade;
}
@Override
void getAllGrade() {
allGrade = finalGrade;
}
}
class GradeC extends Grade {
ArrayList<Integer> usualGrades;
GradeC(ArrayList<Integer> usualGrades) {
this.usualGrades = usualGrades;
}
@Override
void getAllGrade() {
allGrade = 0;
for(int x:usualGrades){
allGrade+=x;
}
allGrade = allGrade/usualGrades.size();
}
}
class Print {
public void personPrint(HashMap<String , Student> students , ArrayList<CourseSelection> courseSelections) {
Set<String> set = students.keySet();
Object[] arr=set.toArray();
Arrays.sort(arr);
for(Object key:arr) {
int x = 0 , y = -1;
for (CourseSelection courseSelection : courseSelections) {
if (students.get(key).getStudentNum().equals(courseSelection.student.getStudentNum())) {
if(y == -1)
y = 0;
courseSelection.grade.getAllGrade();
x += courseSelection.grade.allGrade;
y++;
}
}
if(y == -1) {
System.out.println(students.get(key).getStudentNum()+" "+students.get(key).getName()+" did not take any exams");
continue;
}
x = x / y;
System.out.println(students.get(key).getStudentNum()+" "+students.get(key).getName()+" "+x);
}
}
public void coursePrint(HashMap<String , Course> courses , ArrayList<CourseSelection> courseSelections) {
List<String> list = courses.keySet().stream().collect(Collectors.toList());
Collections.sort(list , new SoftName());
for(String key:list) {
int x = 0 , y = -1 , f = 0 , u = 0 , uy = -1 , s = -1;
for (CourseSelection courseSelection : courseSelections) {
if (courses.get(key).getClassName().equals(courseSelection.course.getClassName())) {
if(y == -1)
y = 0;
if(courses.get(key).getAssessmentMethodology() == 1 && uy == -1)
uy = 0;
if(courses.get(key).getAssessmentMethodology() == 3 && s == -1)
s = 0;
courseSelection.grade.getAllGrade();
x += courseSelection.grade.allGrade;
if(courseSelection.grade instanceof GradeA) {
f += ((GradeA) courseSelection.grade).getFinalGrade();
u += ((GradeA) courseSelection.grade).getUsualGrade();
uy++;
}
if(courseSelection.grade instanceof GradeB) {
f += ((GradeB) courseSelection.grade).getFinalGrade();
}
y++;
}
}
if(y == -1) {
System.out.println(courses.get(key).getClassName()+" has no grades yet");
continue;
}
x = x/y;
f = f/y;
if(s == 0) {
System.out.println(courses.get(key).getClassName()+" "+x);
continue;
}
if(uy == -1) {
System.out.println(courses.get(key).getClassName()+" "+f+" "+x);
}
if(uy != -1) {
u = u/uy;
System.out.println(courses.get(key).getClassName()+" "+u+" "+f+" "+x);
}
}
}
public void classPrint(HashMap<String , Class> classes , ArrayList<CourseSelection> courseSelections) {
Set<String> set = classes.keySet();
Object[] arr=set.toArray();
Arrays.sort(arr);
for(Object key:arr) {
int x = 0 , y = -1;
for(CourseSelection courseSelection : courseSelections) {
if(classes.get(key).students.containsKey(courseSelection.student.getStudentNum())) {
if(y == -1) {
y = 0;
}
courseSelection.grade.getAllGrade();
x += courseSelection.grade.allGrade;
y++;
}
}
if(y == -1) {
System.out.println(classes.get(key).getClassNum()+" has no grades yet");
continue;
}
x = x/y;
System.out.println(classes.get(key).getClassNum()+" "+x);
}
}
public void wrongFormat() {
System.out.println("wrong format");
}
public void courseExist(String name) {
System.out.println(name+" does not exist");
}
public void courseMatch(String studentNum , String studentName) {
System.out.println(studentNum+" "+studentName+" : access mode mismatch");
}
public void courseMatch(String name) {
System.out.println(name+" : course type & access mode mismatch");
}
static class SoftName implements Comparator<String>{
public int compare(String name1 , String name2) {
Comparator<Object> compare = Collator.getInstance(Locale.CHINA);
return compare.compare(name1 , name2);
}
}
}
class MessageGetAndPrint {
Print print;
HashMap<String , Class> classes = new HashMap<>();
HashMap<String , Student> students = new HashMap<>();
HashMap<String , Course> courses = new HashMap<>();
ArrayList<CourseSelection> courseSelections = new ArrayList<>();
public void getMessage(String getInput) {
String[] message = getInput.split(" ");
if(getInput.matches("^(\\S{1,10})( )(必修)$")) {
int i = 1, j = 1;
if(courses.containsKey(message[0])) {
return;
}
Course course = new Course(message[0], i, j);
courses.put(message[0], course);
return;
}
if(getInput.matches("^(\\S{1,10})( )(必修|选修|实验)( )(考试|考察|实验)$")) {
int i = 0, j = 0;
if(message[1].equals("必修")) {
i = 1;
}
if(message[1].equals("选修")) {
i = 2;
}
if(message[1].equals("实验")) {
i = 3;
}
if(message[2].equals("考试")) {
j = 1;
}
if(message[2].equals("考察")) {
j = 2;
}
if(message[2].equals("实验")) {
j = 3;
}
if(i == 1 && j != 1) {
print.courseMatch(message[0]);
return;
}
if(i == 3 && j != 3) {
print.courseMatch(message[0]);
return;
}
if(i != 3 && j == 3) {
print.courseMatch(message[0]);
return;
}
if(courses.containsKey(message[0])) {
return;
}
Course course = new Course(message[0], i, j);
courses.put(message[0], course);
return;
}
if(getInput.matches("^([0-9]{8})( )(\\S{1,10})( )(\\S{1,10})( )([0-9]|[1-9][0-9]|100)( )([0-9]|[1-9][0-9]|100)$")) {
for(CourseSelection courseSelection:courseSelections) {
if(courseSelection.student.getStudentNum().equals(message[0])&&courseSelection.student.getName().equals(message[1])&&courseSelection.course.getClassName().equals(message[2])) {
return;
}
}
Student student = new Student(message[1], message[0]);
students.put(message[0] , student);
String classNum = message[0].substring(0 , 6);
if(!classes.containsKey(classNum)) {
Class aClass = new Class(classNum);
classes.put(classNum , aClass);
classes.get(classNum).students = new HashMap<>();
}
classes.get(classNum).students.put(message[0], student);
if(!courses.containsKey(message[2])) {
print.courseExist(message[2]);
return;
}
if(courses.get(message[2]).getAssessmentMethodology() != 1) {
print.courseMatch(message[0] , message[1]);
return;
}
CourseSelection courseSelection = new CourseSelection();
courseSelection.student = student;
courseSelection.course = courses.get(message[2]);
int finalGrade = Integer.parseInt(message[4]);
int usualGrade = Integer.parseInt(message[3]);
courseSelection.grade = new GradeA(finalGrade , usualGrade);
courseSelections.add(courseSelection);
return;
}
if(getInput.matches("^([0-9]{8})( )(\\S{1,10})( )(\\S{1,10})( )([0-9]|[1-9][0-9]|10{2})$")) {
for(CourseSelection courseSelection:courseSelections) {
if(courseSelection.student.getStudentNum().equals(message[0])&&courseSelection.student.getName().equals(message[1])&&courseSelection.course.getClassName().equals(message[2])) {
return;
}
}
Student student = new Student(message[1], message[0]);
students.put(message[0] , student);
String classNum = message[0].substring(0 , 6);
if(!classes.containsKey(classNum)) {
Class aClass = new Class(classNum);
classes.put(classNum , aClass);
classes.get(classNum).students = new HashMap<>();
}
classes.get(classNum).addStudent(student);
if(!courses.containsKey(message[2])) {
print.courseExist(message[2]);
return;
}
if(courses.get(message[2]).getAssessmentMethodology() != 2) {
print.courseMatch(message[0] , message[1]);
return;
}
CourseSelection courseSelection = new CourseSelection();
courseSelection.student = student;
courseSelection.course = courses.get(message[2]);
int finalGrade = Integer.parseInt(message[3]);
courseSelection.grade = new GradeB(finalGrade);
courseSelections.add(courseSelection);
return;
}
if(getInput.matches("^([0-9]{8})( )(\\S{1,10})( )(\\S{1,10})( )([4-9])( )((([0-9]|[1-9][0-9]|100)( ))+)([0-9]|[1-9][0-9]|100)$")) {
for(CourseSelection courseSelection:courseSelections) {
if(courseSelection.student.getStudentNum().equals(message[0])&&courseSelection.student.getName().equals(message[1])&&courseSelection.course.getClassName().equals(message[2])) {
return;
}
}
Student student = new Student(message[1], message[0]);
students.put(message[0] , student);
String classNum = message[0].substring(0 , 6);
if(!classes.containsKey(classNum)) {
Class aClass = new Class(classNum);
classes.put(classNum , aClass);
classes.get(classNum).students = new HashMap<>();
}
classes.get(classNum).addStudent(student);
if(!courses.containsKey(message[2])) {
print.courseExist(message[2]);
return;
}
if(courses.get(message[2]).getAssessmentMethodology() != 3) {
print.courseMatch(message[0] , message[1]);
return;
}
int usualNum = Integer.parseInt(message[3]);
if(message.length-4 != usualNum) {
print.courseMatch(message[0] , message[1]);
return;
}
CourseSelection courseSelection = new CourseSelection();
courseSelection.student = student;
courseSelection.course = courses.get(message[2]);
ArrayList<Integer> usualGrades = new ArrayList<>();
for(int i = 1;i <= usualNum;i++) {
usualGrades.add(Integer.parseInt(message[3+i]));
}
courseSelection.grade = new GradeC(usualGrades);
courseSelections.add(courseSelection);
return;
}
print.wrongFormat();
}
}


-
定义数据结构: 定义课程信息和成绩信息的数据结构。对于课程信息,可以使用一个字典来表示,其中课程名称作为键,课程性质和考核方式作为值。对于成绩信息,可以使用一个学生ID作为键,对应的值是一个包含该学生的所有成绩信息的列表。
-
输入处理: 编写函数来解析输入的字符串,并将信息存储到相应的数据结构中。
-
成绩计算: 编写函数来计算成绩。遍历存储成绩信息的数据结构,根据题目给出的计算规则,计算每个学生的总成绩和每门课程的平均成绩。
-
格式化输出: 编写函数来按照题目描述的格式输出计算结果。根据题目要求,输出学生所有课程总成绩的平均分、单门课程成绩平均分、单门课程总成绩平均分、班级所有课程总成绩平均分等内容。
-
异常情况处理: 对于输入错误或不符合规定的情况,需要进行相应的异常处理,并按照题目要求输出相应的提示信息。
本题为上一道的拓展,没有多大变化,新增一个实验课的情况,主要难点在于使用正则表达式判断对于数据的处理,以及如何判断实验课的实验次数和输入的实验成绩数不匹配的情况。
改进建议: 为了提高代码的可读性和可维护性,建议将输入处理、成绩计算和输出格式化等功能分别封装成函数,以便于管理和调试。
课程成绩统计程序-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.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.text.Collator;
import java.util.*;
import java.util.stream.Collectors;
public class Main {
public static void main(String[] args) throws IOException {
BufferedReader in = new BufferedReader(new InputStreamReader(System.in));
MessageGetAndPrint messageGetAndPrint = new MessageGetAndPrint();
messageGetAndPrint.print = new Print();
for(;;){
String message = in.readLine();
if(message.equals("end")) {
messageGetAndPrint.print.personPrint(messageGetAndPrint.students , messageGetAndPrint.courseSelections);
messageGetAndPrint.print.coursePrint(messageGetAndPrint.courses , messageGetAndPrint.courseSelections);
messageGetAndPrint.print.classPrint(messageGetAndPrint.classes , messageGetAndPrint.courseSelections);
break;
}
messageGetAndPrint.getMessage(message);
}
}
}
class Class {
private String classNum;
HashMap<String , Student> students;
Class(String classNum) {
setClassNum(classNum);
}
public void setClassNum(String classNum) {
this.classNum = classNum;
}
public String getClassNum() {
return classNum;
}
public void addStudent(Student student) {
students.put(student.getStudentNum() , student);
}
}
class Student {
private String name;
private String studentNum;
Student(String name , String studentNum) {
setName(name);
setStudentNum(studentNum);
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getStudentNum() {
return studentNum;
}
public void setStudentNum(String studentNum) {
this.studentNum = studentNum;
}
}
class Course {
private String className;
private int classQuality;
private int assessmentMethodology;
ArrayList<Float> weightFunction = new ArrayList<>();
Course(String className , int classQuality , int assessmentMethodology) {
setClassName(className);
setClassQuality(classQuality);
setAssessmentMethodology(assessmentMethodology);
}
public String getClassName() {
return className;
}
public void setClassName(String className) {
this.className = className;
}
public int getClassQuality() {
return classQuality;
}
public void setClassQuality(int classQuality) {
this.classQuality = classQuality;
}
public int getAssessmentMethodology() {
return assessmentMethodology;
}
public void setAssessmentMethodology(int assessmentMethodology) {
this.assessmentMethodology = assessmentMethodology;
}
}
class CourseSelection {
Student student;
Course course;
Grade grade;
}
class Grade {
SubItemGrades subItemGrades = new SubItemGrades();
public int getGrade(){
float allGrades = 0;
for(int i = 0;i<subItemGrades.subItem.size();i++) {
allGrades += subItemGrades.subItem.get(i)*subItemGrades.grades.get(i);
}
return (int) allGrades;
}
}
class SubItemGrades {
ArrayList<Integer> grades = new ArrayList<>();
ArrayList<Float> subItem = new ArrayList<>();
}
class Print {
public void personPrint(HashMap<String , Student> students , ArrayList<CourseSelection> courseSelections) {
Set<String> set = students.keySet();
Object[] arr=set.toArray();
Arrays.sort(arr);
for(Object key:arr) {
int x = 0 , y = 0 , z = -1;
for (CourseSelection courseSelection : courseSelections) {
if (students.get(key).getStudentNum().equals(courseSelection.student.getStudentNum())) {
z = 0;
x += courseSelection.grade.getGrade();
y++;
}
}
if(z == -1) {
System.out.println(students.get(key).getStudentNum()+" "+students.get(key).getName()+" did not take any exams");
}
if(z == 0) {
x = x / y;
System.out.println(students.get(key).getStudentNum()+" "+students.get(key).getName()+" "+x);
}
}
}
public void coursePrint(HashMap<String , Course> courses , ArrayList<CourseSelection> courseSelections) {
List<String> list = courses.keySet().stream().collect(Collectors.toList());
Collections.sort(list , new SoftName());
for(String key:list) {
int x = 0 , y = 0 , z = -1;
for (CourseSelection courseSelection : courseSelections) {
if (courses.get(key).getClassName().equals(courseSelection.course.getClassName())) {
z = 0;
x += courseSelection.grade.getGrade();
y++;
}
}
if(z == -1) {
System.out.println(courses.get(key).getClassName()+" has no grades yet");
}
if(z == 0) {
x = x/y;
System.out.println(courses.get(key).getClassName()+" "+x);
}
}
}
public void classPrint(HashMap<String , Class> classes , ArrayList<CourseSelection> courseSelections) {
Set<String> set = classes.keySet();
Object[] arr=set.toArray();
Arrays.sort(arr);
for(Object key:arr) {
int x = 0 , y = 0 , z = -1;
for(CourseSelection courseSelection : courseSelections) {
if(classes.get(key).students.containsKey(courseSelection.student.getStudentNum())) {
z = 0;
x += courseSelection.grade.getGrade();
y++;
}
}
if(z == -1) {
System.out.println(classes.get(key).getClassNum()+" has no grades yet");
}
if(z == 0) {
x = x/y;
System.out.println(classes.get(key).getClassNum()+" "+x);
}
}
}
public void wrongFormat() {
System.out.println("wrong format");
}
public void courseExist(String name) {
System.out.println(name+" does not exist");
}
public void courseMatch(String studentNum , String studentName) {
System.out.println(studentNum+" "+studentName+" : access mode mismatch");
}
public void courseMatch(String name) {
System.out.println(name+" : course type & access mode mismatch");
}
public void numMatch(String name) {
System.out.println(name+" : number of scores does not match");
}
public void weightValue(String name) {
System.out.println(name+" : weight value error");
}
static class SoftName implements Comparator<String>{
public int compare(String name1 , String name2) {
Comparator<Object> compare = Collator.getInstance(Locale.CHINA);
return compare.compare(name1 , name2);
}
}
}
class MessageGetAndPrint {
Print print;
HashMap<String , Class> classes = new HashMap<>();
HashMap<String , Student> students = new HashMap<>();
HashMap<String , Course> courses = new HashMap<>();
ArrayList<CourseSelection> courseSelections = new ArrayList<>();
public void getMessage(String getInput) {
String[] message = getInput.split(" ");
if(getInput.matches("^(\\S{1,10})( )(必修|选修|实验)( )(考试|考察|实验)$") ||
getInput.matches("^(\\S{1,10})( )(必修|选修|实验)( )(考试|考察|实验)( )((0.(0)+[1-9]|0.[1-9][0-9]*)( )(0.(0)+[1-9]|0.[1-9][0-9]*)$)") ||
getInput.matches("^(\\S{1,10})( )(必修|选修|实验)( )(考试|考察|实验)( )([4-9])((( )(0.(0)+[1-9]|0.[1-9][0-9]*|1))*)(( )(0.(0)+[1-9]|0.[1-9][0-9]*))$")
) {
if(courses.containsKey(message[0])) {
return;
}
int i = 0, j = 0;
if(message[1].equals("必修")) {
i = 1;
}
if(message[1].equals("选修")) {
i = 2;
}
if(message[1].equals("实验")) {
i = 3;
}
if(message[2].equals("考试")) {
j = 1;
}
if(message[2].equals("考察")) {
j = 2;
}
if(message[2].equals("实验")) {
j = 3;
}
if((i == 1 && j != 1) || (i == 3 && j != 3) || (i != 3 && j == 3) ) {
print.courseMatch(message[0]);
return;
}
if((j == 1 && message.length != 5) || (j == 2 && message.length != 3) || (j == 3 && message.length - 4 != Integer.parseInt(message[3]))) {
print.numMatch(message[0]);
return;
}
if(j == 1 && Float.parseFloat(message[3])+Float.parseFloat(message[4]) != 1) {
print.weightValue(message[0]);
return;
}
if(j == 3) {
float value = 0;
for(int k = 0 ; k < Integer.parseInt(message[3]) ; k++) {
value += Float.parseFloat(message[4+k]);
}
if(value>1.001||value<0.999) {
print.weightValue(message[0]);
return;
}
}
Course course = new Course(message[0], i, j);
if(j == 1) {
course.weightFunction.add(Float.parseFloat(message[3]));
course.weightFunction.add(Float.parseFloat(message[4]));
}
if(j == 2)
course.weightFunction.add(1F);
if(j == 3) {
for(int k = 0 ; k < Integer.parseInt(message[3]) ; k++) {
course.weightFunction.add(Float.parseFloat(message[4+k]));
}
}
courses.put(message[0], course);
}
else if(getInput.matches("^([0-9]{8})( )(\\S{1,10})( )(\\S{1,10})( )([0-9]|[1-9][0-9]|100)$") ||
getInput.matches("^([0-9]{8})( )(\\S{1,10})( )(\\S{1,10})( )([0-9]|[1-9][0-9]|100)( )([0-9]|[1-9][0-9]|100)$") ||
getInput.matches("^([0-9]{8})( )(\\S{1,10})( )(\\S{1,10})( )((([0-9]|[1-9][0-9]|100)( ))*)([0-9]|[1-9][0-9]|100)$")
) {
for(CourseSelection courseSelection:courseSelections) {
if(courseSelection.student.getStudentNum().equals(message[0])&&courseSelection.student.getName().equals(message[1])&&courseSelection.course.getClassName().equals(message[2])) {
return;
}
}
Student student = new Student(message[1], message[0]);
students.put(message[0] , student);
String classNum = message[0].substring(0 , 6);
if(!classes.containsKey(classNum)) {
Class aClass = new Class(classNum);
classes.put(classNum , aClass);
classes.get(classNum).students = new HashMap<>();
}
classes.get(classNum).addStudent(student);
if(!courses.containsKey(message[2])) {
print.courseExist(message[2]);
return;
}
if(message.length - 3 != courses.get(message[2]).weightFunction.size()) {
print.courseMatch(message[0] , message[1]);
return;
}
CourseSelection courseSelection = new CourseSelection();
courseSelection.student = student;
courseSelection.course = courses.get(message[2]);
Grade grade = new Grade();
for(int i = 0 ; i < message.length - 3 ; i++) {
grade.subItemGrades.grades.add(Integer.parseInt(message[3+i]));
}
grade.subItemGrades.subItem = courses.get(message[2]).weightFunction;
courseSelection.grade = grade;
courseSelections.add(courseSelection);
}
else
print.wrongFormat();
}
}


考试以及实验的权重值发生变化,并在输入课的时候确定(包括实验课的实验次数),后续的输入成绩数量跟对应课程权重数量一致。对于计算成绩方式也发生变化,将成绩乘以对应权重并求和,最后输出Int类型数据忽略小数点。此题要求改变成绩类,从原来的继承关系转换成一个成绩类并改为组合关系,成绩信息由课程成绩类和分项成绩类组成,课程成绩类组合分项成绩类,分项成绩类由成绩分值和权重两个属性构成。
编程求得正方体和正三棱锥的表面积和体积,要求必须体现扩展性(继承)和多态性。
类结构如下图所示(参考):

试编程完成如上类设计,主方法源码如下(可直接拷贝使用):
public static void main(String[] args) {
// TODO Auto-generated method stub
Scanner input = new Scanner(System.in);
double side = input.nextDouble();
display(new Cube(side));
display(new RegularPyramid(side));
}
其中,display(Solid solid)方法为定义在Main类中的静态方法,作用为体现程序的多态性。
注:正三棱锥的体积计算公式为底面积*高/3。
输入格式:
输入一个实型数,分别作为正方体的边长和正三棱锥的边长。
输出格式:
分别输出正方体的表面积、体积以及正棱锥的表面积和体积。保留两位小数,建议使用String.format(“%.2f”,value)
进行小数位数控制。
输入样例:
在这里给出一组输入。例如:
2.5
输出样例:
在这里给出相应的输出。例如:
37.50
15.63
10.83
1.84
import java.util.Scanner;
class solid {
}
class Cube extends solid {//立方体
private double bianchang;
public Cube(double bianchang) {
this.bianchang = bianchang;
}
public Cube() {
}
public double getBianchang() {
return bianchang;
}
public void setBianchang(double bianchang) {
this.bianchang = bianchang;
}
public double getSurfaceArea() {
return 6 * bianchang * bianchang;
}
public double getVolume() {
return bianchang * bianchang * bianchang;
}
}
class RegularPyramid extends solid {
private double bianchang;
public RegularPyramid() {
}
public RegularPyramid(double bianchang) {
this.bianchang = bianchang;
}
public double getBianchang() {
return bianchang;
}
public void setBianchang(double bianchang) {
this.bianchang = bianchang;
}
public double getmianji() {
// 正三棱锥的表面积计算公式为4 * 底面积
double baseArea = (Math.sqrt(3) / 4) * Math.pow(bianchang, 2);
return 4 * baseArea;
}
public double getVolome() {
// 正三棱锥的体积计算公式为底面积 * 高 / 3
double baseArea = (Math.sqrt(3) / 4) * Math.pow(bianchang, 2);
double height = Math.sqrt(2 / 3.0) * bianchang; // 高为底边长度的sqrt(2/3)倍
return baseArea * height / 3;
}
}
public class Main {
public static void main(String[] args) {
Scanner input = new Scanner(System.in);
Double inputnums = input.nextDouble();;
double cube = inputnums;
double sanlengzhui = inputnums;
show(new Cube(cube));
show(new RegularPyramid(sanlengzhui));
}
public static void show(solid solid) {
if (solid instanceof Cube) {
Cube cube = (Cube) solid;
System.out.println(String.format("%.2f", cube.getSurfaceArea()));
System.out.println(String.format("%.2f", cube.getVolume()));
} else if (solid instanceof RegularPyramid) {
RegularPyramid pyramid = (RegularPyramid) solid;
System.out.println(String.format("%.2f", pyramid.getmianji()));
System.out.println(String.format("%.2f", pyramid.getVolome()));
}
}
}


比较简单拿分,非常基础。
问题描述:本问题中的魔方有两种,一种是正方体魔方,一种是正三棱锥魔方,其中,正方体或正三棱锥魔方是由单元正方体或正三棱锥组成,单元正方体或正三棱锥的个数由阶数(即层数)决定,即魔方边长=阶数*单元边长。魔方如下图所示:

利用“立体图形”问题源码,实现如下功能:
魔方有三个属性:颜色,阶数,类型(正方体魔方、正三棱锥魔方),程序要求输出魔方的颜色、表面积和体积。参考设计类图如下所示:

主方法部分可参考如下源码(可拷贝直接使用):
public class Main {
public static void main(String[] args) {
// TODO Auto-generated method stub
Scanner input = new Scanner(System.in);
String color = input.next();
int layer = input.nextInt();
double side = input.nextDouble();
RubikCube cube1 = new SquareCube(color, layer,new Cube(side));
color = input.next();
layer = input.nextInt();
side = input.nextDouble();
RubikCube cube2 = new RegularPyramidCube(color, layer,new RegularPyramid(side));
display(cube1);
display(cube2);
}
}
其中,display(RubikCube cube)方法为Main类中定义的静态方法,用户输出魔方的信息,用于体现多态性。
输入格式:
第一部分:正方体魔方颜色、阶数、单元正方体边长,以空格或回车分隔;
第二部分:正三棱锥魔方颜色、阶数、单元正三棱锥边长,以空格或回车分隔。
输出格式:
正方体魔方颜色
正方体魔方表面积
正方体魔方体积
正三棱锥魔方颜色
正三棱锥魔方表面积
正三棱锥魔方体积
注:小数点保留两位
输入样例:
在这里给出一组输入。例如:
red 3 4.5
black 4 2.1
输出样例:
在这里给出相应的输出。例如:
red
1093.50
2460.38
black
122.21
69.85
import java.util.Scanner;
class Cube {
private double bianchang;
public Cube(double bianchang) {
this.bianchang = bianchang;
}
public double getBianchang() {
return bianchang;
}
public double getmianji() {
return 6 * bianchang * bianchang;
}
public Cube() {
}
public double gettiji() {
return bianchang * bianchang * bianchang;
}
public void setBianchang(double bianchang) {
this.bianchang = bianchang;
}
}
// 定义正方体魔方类
class SCube extends mofang {
private Cube type;
public SCube(String color, int layer, Cube type) {
super(color, layer);
this.type = type;
}
@Override
public double calculateSurfaceArea() {
return type.getmianji();
}
@Override
public double calculateVolume() {
return type.gettiji();
}
}
// 定义正三棱锥类
class RegularPyramid {
private double bianchang;
public RegularPyramid(double bianchang) {
this.bianchang = bianchang;
}
public double getBianchang() {
return bianchang;
}
public double calculateSurfaceArea() {
double baseArea = (Math.sqrt(3) / 4) * Math.pow(bianchang, 2);
return 4 * baseArea;
}
public double calculateVolume() {
// 正三棱锥的体积计算公式为底面积 * 高 / 3
double baseArea = (Math.sqrt(3) / 4) * Math.pow(bianchang, 2);
double height = Math.sqrt(2 / 3.0) * bianchang; // 高为底边长度的sqrt(2/3)倍
return baseArea * height / 3;
}
}
// 定义正三棱锥魔方类
class RegularPyramidCube extends mofang {
private RegularPyramid unitPyramid;
public RegularPyramidCube(String color, int layer, RegularPyramid unitPyramid) {
super(color, layer);
this.unitPyramid = unitPyramid;
}
@Override
public double calculateSurfaceArea() {
return unitPyramid.calculateSurfaceArea();
}
@Override
public double calculateVolume() {
return unitPyramid.calculateVolume();
}
}
// 定义魔方抽象类
abstract class mofang {
private String color;
private int layer;
public mofang(String color, int layer) {
this.color = color;
this.layer = layer;
}
public String getColor() {
return color;
}
public int getLayer() {
return layer;
}
public abstract double calculateSurfaceArea();
public abstract double calculateVolume();
}
// 主类
public class Main {
public static void main(String[] args) {
Scanner input = new Scanner(System.in);
String color = input.next();
int layer = input.nextInt();
double side = input.nextDouble();
mofang cube1 = new SCube(color, layer, new Cube(layer * side));
color = input.next();
layer = input.nextInt();
side = input.nextDouble();
mofang cube2 = new RegularPyramidCube(color, layer, new RegularPyramid(layer * side));
show(cube1);
show(cube2);
}
public static void show(mofang cube) {
System.out.println(cube.getColor());
System.out.printf("%.2f\n", cube.calculateSurfaceArea());
System.out.printf("%.2f\n", cube.calculateVolume());
}
}


作为上一题的拓展,难度也是一般,在考试是由于一些小错误,当时没有打注释,运行结果的数据是错误的但是公式以及计算的过程都没有变,debug查了一段时间发现是延续的上一题的return作了修改
导致多乘了阶数,这里耗费了许久导致后面时间不太够。
在魔方问题的基础上,重构类设计,实现列表内魔方的排序功能(按照魔方的体积进行排序)。
提示:题目中RubikCube类要实现Comparable接口。
其中,Main类源码如下(可直接拷贝使用):
public class Main {
public static void main(String[] args) {
// TODO Auto-generated method stub
Scanner input = new Scanner(System.in);
String color;
int layer;
double side;
RubikCube cube;
ArrayList<RubikCube> list = new ArrayList<>();
int choice = input.nextInt();
while(choice != 0) {
switch(choice) {
case 1://SquareCube
color = input.next();
layer = input.nextInt();
side = input.nextDouble();
cube = new SquareCube(color, layer,new Cube(side));
list.add(cube);
break;
case 2://RegularPyramidCube
color = input.next();
layer = input.nextInt();
side = input.nextDouble();
cube = new RegularPyramidCube(color, layer,new RegularPyramid(side));
list.add(cube);
break;
}
choice = input.nextInt();
}
list.sort(Comparator.naturalOrder());//正向排序
for(int i = 0; i < list.size(); i++) {
System.out.print(list.get(i).getColor() + " " +
String.format("%.2f", list.get(i).getArea()) + " " +
String.format("%.2f", list.get(i).getVolume()) );
System.out.println("");
}
}
}
输入格式:
输入魔方类型(1:正方体魔方;2:正三棱锥魔方;0:结束输入)
魔方颜色、魔方阶数、魔方单元正方体、正三棱锥边长
..循环..
输出格式:
按魔方体积升序输出列表中各魔方的信息(实型数均保留两位小数),输出样式参见输出样例。
输入样例:
在这里给出一组输入。例如:
1 blue 3 4.5
2 red 4 2.1
1 yellow 5 2.3
2 black 4 9.42
1 white 4 5.4423
0
输出样例:
在这里给出相应的输出。例如:
red 122.21 69.85
yellow 793.50 1520.88
blue 1093.50 2460.38
black 2459.14 6304.73
white 2843.39 10316.38
前亚利桑那州境内的一位步枪销售商销售密苏里州制造的步枪机(lock)、枪托(stock)和枪管(barrel)。枪机卖45美元,枪托卖30美元,枪管卖25美元。销售商每月至少要售出一支完整的步枪,且生产限额是销售商在一个月内可销售70个枪机、80个枪托和90个枪管。
根据每个月的销售情况,计算销售商的佣金(提成)算法如下:
-
不到(含)1000美元的部分为10%;
-
1000(含)~1800美元的部分为15%;
-
超过1800美元的部分为20%。
佣金程序生成月份销售报告,汇总销售商的销售总额和佣金。
编程要求:必须符合面向对象编程,且保证类设计的单一职责模式,使用面向过程编程判定0分。
提示:可以设置一个销售订单类。参考类图如下:

输入格式:
输入销售商每个月售出枪机、枪托、枪管的数量,可以用空格或者回车分隔。
输出格式:
分别输出销售商在该月的销售额和佣金,中间用空格分开。
输入样例1:
在这里给出一组输入。例如:
30 40 50
输出样例1:
在这里给出相应的输出。例如:
3800.00 620.00
输入样例2:
在这里给出一组输入。例如:
88 56 98
输出样例2:
在这里给出相应的输出。例如:
Wrong Format
import java.util.Scanner;
// Lock class
class Lock {
private int quantity;
public Lock(int quantity) {
this.quantity = quantity;
}
public int getQuantity() {
return quantity;
}
}
// Stock class
class Stock {
private int quantity;
public Stock(int quantity) {
this.quantity = quantity;
}
public int getQuantity() {
return quantity;
}
}
// Barrel class
class Barrel {
private int quantity;
public Barrel(int quantity) {
this.quantity = quantity;
}
public int getQuantity() {
return quantity;
}
}
// SalesOrder class
class SalesOrder {
private Lock lock;
private Stock stock;
private Barrel barrel;
public SalesOrder(Lock lock, Stock stock, Barrel barrel) {
this.lock = lock;
this.stock = stock;
this.barrel = barrel;
}
public Lock getLock() {
return lock;
}
public Stock getStock() {
return stock;
}
public Barrel getBarrel() {
return barrel;
}
}
// CommissionCalculator class
class CommissionCalculator {
private static double LOCK_PRICE = 45.0;
private static double STOCK_PRICE = 30.0;
private static double BARREL_PRICE = 25.0;
public static double calculateTotalSales(SalesOrder salesOrder) {
int lockQuantity = salesOrder.getLock().getQuantity();
int stockQuantity = salesOrder.getStock().getQuantity();
int barrelQuantity = salesOrder.getBarrel().getQuantity();
double totalSales = (lockQuantity * LOCK_PRICE) +
(stockQuantity * STOCK_PRICE) +
(barrelQuantity * BARREL_PRICE);
return totalSales;
}
public static double calculateCommission(double totalSales) {
double commission = 0.0;
if (totalSales <= 1000) {
commission = totalSales * 0.10;
} else if (totalSales <= 1800) {
double firstTier = 1000 * 0.10;
double remainingSales = totalSales - 1000;
commission = firstTier + (remainingSales * 0.15);
} else {
double firstTier = 1000 * 0.10;
double secondTier = 800 * 0.15;
double remainingSales = totalSales - 1800;
commission = firstTier + secondTier + (remainingSales * 0.20);
}
return commission;
}
}
// Main program
public class Main {
public static void main(String[] args) {
Scanner input = new Scanner(System.in);
int locknum = input.nextInt();
Lock lock = new Lock(locknum);
int stocknum = input.nextInt();
Stock stock = new Stock(stocknum);
int barrelnum = input.nextInt();
Barrel barrel = new Barrel(barrelnum);
SalesOrder salesOrder = new SalesOrder(lock, stock, barrel);
double totalSales = CommissionCalculator.calculateTotalSales(salesOrder);
System.out.print(String.format("%.2f",totalSales));
System.out.print(" ");
System.out.print(String.format("%.2f",CommissionCalculator.calculateCommission(totalSales)));
}
}



这里时间不太够写完提交发现还有数值限制……在类里加条件应该就可解决
总结:
首先,我在两次成绩计算中的代码中,发现有些代码缺乏的注释和说明,尤其是在写2时,由于1写的比较早使用的一些方法比较简单粗暴不规范,这给理解以及后续的修改代码过程带来了一定的困难。真心建议在代码中多添加一些注释,对关键部分进行解释,以便他人或者未来的自己(?)能够更容易地理解代码的逻辑和功能。其次,我在代码中也注意到了一些命名不够规范和不一致的情况。为了提高代码的可读性和维护性,还是建议使用驼峰并且有意义且一致的变量和方法命名。这样在阅读代码时更加容易理解其含义,并且在后续的开发和维护过程中也更加方便。此外,代码中还存在一些硬编码的问题,即直接在代码中写入具体数值等信息。在处理用户输入和操作时,应该考虑到可能出现的异常情况,并进行相应的错误处理。这样的一些好习惯尤其在写一些比较长的代码需要时间长或者合作的时候的十分的有必要。
在代码设计方面存在大量重复代码,代码的复用率不高。建议将一些相似的操作单独封装成方法,以便在需要时直接调用,提高代码的复用性。另外,对于数据的判断和处理,也可以将其封装成一个独立的判断方法,使代码的关联性更分散,增加代码的灵活性和可扩展性。经过了这么多次的练习之后还是有一些收获的而不是像以前一样只求做出来,我开始思考题目的需求和哪些方法匹配,字符匹配是否需要用到正则表达式,类的设计是应该继承还是组合,是否符合各个原则,不符合要怎么修改……
这样的思考让我不再仅仅追求完成任务,而是更注重代码的质量和设计。

浙公网安备 33010602011771号