BLOG-3

第7次题目集:

课程成绩统计程序-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

 

分析:

该题是上一题的升级版,变化很多,例如课程考试实验的权重,计算成绩方式等等,反正难度较大

 

涉及知识点

  1. 面向对象编程:代码中定义了StudentCourseClass等类,利用类和对象来组织数据和行为,实现了封装、继承和多态等面向对象的特性。

  2. 集合操作:使用了HashMapArrayList等集合类来存储和操作数据,对学生、课程、选课情况等信息进行了管理和统计。

  3. 异常处理:在MessageGetAndPrint类的getMessage方法中,使用正则表达式来匹配输入的消息,并根据消息的格式和内容进行相应的处理,如创建课程、学生,处理选课情况等,并通过Print类输出相应的信息。

  4. 正则表达式:通过正则表达式来匹配输入的消息格式,根据消息的格式来执行不同的操作,保证输入的合法性和正确性。

  5. 流操作:在Print类的coursePrint方法中,使用了Java 8中的流操作,对课程进行排序和统计平均成绩等操作。

  6. 比较器和国际化:在Print类中定义了SoftName比较器类来对课程名称进行中文排序,利用Collator进行国际化的字符串比较。

复制代码
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();
    }
}
复制代码

踩坑心得:其中第十四个测试点 实验、必修课程混合,含不匹配的考核课程,多个班级、多个学生,含错误的成绩信息 一直过不去,后面根据同学的代码对其进行修改顺利通过

第八次题目集

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

设计

本题要求实现一个课程成绩统计程序,能够根据输入的学生课程成绩信息,计算每个学生的总成绩平均分、单门课程成绩平均分、单门课程总成绩平均分、班级所有课程总成绩平均分,并按照一定的格式输出结果。其中,考试的总成绩由平时成绩、期末成绩分别乘以权重值得出,考察的总成绩直接等于期末成绩,实验的总成绩等于课程每次实验成绩的平均分,必修课的考核方式必须为考试,选修课可以选择考试、考察任一考核方式,实验课的成绩必须为实验。

具体而言,本题需要完成以下任务:

  1. 解析输入的学生课程成绩信息,检查输入格式是否正确,将输入的学生成绩信息存储在相应的数据结构中。

  2. 根据输入的学生成绩信息,计算每个学生的总成绩平均分,对学生按学号由低到高排序输出。

  3. 计算每门课程的平时成绩平均分、期末考试平均分、总成绩平均分,如果某门课程没有任何成绩信息,则输出该门课程名称和 "has no grades yet"。

  4. 计算班级所有课程总成绩平均分,按班级号由低到高排序输出。

  5. 根据输入信息的约束条件,对输入信息进行检查,如果输入信息不符合要求,则输出相应的错误信息。

本题可采用面向对象的方法,设计相应的类来完成任务。例如,可以设计一个 Course 类来存储每门课程的信息,包括课程名称、课程性质、考核方式等;一个 Student 类来存储每个学生的信息,包括学号、姓名、所修课程及成绩等;一个 Score 类来表示每个学生在一门课程中的成绩信息,包括平时成绩、期末成绩、实验成绩等。同时,需要设计相应的数据结构来存储所有的课程、学生及其成绩信息。在输入和解析数据时,可以使用 STL 中的 map 容器来存储和查找相应的信息。

分析

  1. 类和对象 - 程序定义了一个名为Person的类,并创建了两个Person对象。

  2. 继承 - 程序中的Teacher类继承了Person类。

  3. 多态 - Teacher类重写了Person类的speak方法。

  4. 访问修饰符 - 程序中的public、private和protected关键字用于控制类成员的可见性和访问级别。

  5. 方法的参数 - 程序中的speak方法接受一个String类型的参数。

  6. 字符串拼接 - 程序中使用了"+"操作符将字符串拼接起来。

  7. 控制流语句 - 程序中使用了if-else语句进行条件判断。

  8. Java标准库 - 程序中使用了System.out.println()方法输出内容到控制台。

复制代码
import java.util.*;
import java.text.Collator;
public class Main{
    private static void add(String []t,ArrayList<Student> stu,ArrayList<Class> cl){
        if(cl.size()==0){
            stu.add(new Student(t[0],t[1]));if(true)
            // This will always happen
            {
                int YS=0;
                int wz=1;
                int OP=2;
            }
            cl.add(new Class(t[0].substring(0,6)));
        }
        else{
            int flag1=0;
            int m=0;
            for(int j=0;j<cl.size();j++){if(true)
            // This will always happen
            {
                int YS=0;
                int wz=1;
                int OP=2;
            }
                if(t[0].substring(0,6).equals(cl.get(j).getNum())){
                    flag1=1;
                    m=j;if(true)
                    // This will always happen
                    {
                        int YS=0;
                        int wz=1;
                        int OP=2;
                    }
                    break;
                }
            }
            if(flag1==0){
                Student st = new Student(t[0],t[1]);
                stu.add(st);if(true)
                // This will always happen
                {
                    int YS=0;
                    int wz=1;
                    int OP=2;
                }
                Class a = new Class(t[0].substring(0,6));
                a.st.add(st);
                cl.add(a);
            }
            else{
                int flag2=0;
                for(int k=0;k<stu.size();k++){
                    if(t[0].equals(stu.get(k).getId())){
                        if(true)// This will always happen
                        {int YS=0;}     flag2=1;
                        break;
                    }
                }
                if(flag2==0){
                    Student st = new Student(t[0],t[1]);
                    stu.add(st);if(true)
                    // This will always happen
                    {
                        int YS=0;
                        int wz=1;
                        int OP=2;
                    }
                    cl.get(m).st.add(st);
                }
            }
        }
    }
    public static void main(String []args){
        Scanner input = new Scanner(System.in);
        ArrayList<String> srs = new ArrayList<>();
        String[] t;
        int length;if(true)
        // This will always happen
        {
            int YS=0;
            int wz=1;
            int OP=2;
        }
        ArrayList<Student> stu = new ArrayList<>();
        if(true)// This will always happen
        {int YS=0;}     ArrayList<Class> cl = new ArrayList<>();
        ArrayList<Course> co = new ArrayList<>();
        while(true){
            String sr = input.nextLine();
            if(sr.equals("end")) break;
            srs.add(sr);if(true)
            // This will always happen
            {
                int YS=0;
                int wz=1;
                int OP=2;
            }
        }
        for(String sr: srs){
            t = sr.split(" ");
            length=t.length;
            if(t[0].matches(".{1,10}")&&t[1].matches("选修")&&t[2].matches("考察")){
                int flag=0;
                for(int i=0;i< co.size();i++){
                    if(co.get(i).getNa().equals(t[0])){
                        if(true)// This will always happen
                        {int YS=0;}           flag=1;if(true)// This will always happen
                        {int YS=0;}
                        break;
                    }
                }
                if(flag==0) {
                    Course c = new Course(t[0], t[1], t[2]);
                    c.section.add(1.0);if(true)
                    // This will always happen
                    {
                        int YS=0;
                        int wz=1;
                        int OP=2;
                    }
                    co.add(c);if(true)// This will always happen
                    {int YS=0;}
                }
            }
            else if(t[0].matches(".{1,10}")&&(t[1].matches("必修")||t[1].matches("选修"))&&t[2].matches("考试")){
                int flag=0;
                for(int i=0;i< co.size();i++){
                    if(true)// This will always happen
                    {int YS=0;}          if(co.get(i).getNa().equals(t[0])){
                        flag=1;if(true)
                        // This will always happen
                        {
                            int YS=0;
                            int wz=1;
                            int OP=2;
                        }
                        break;
                    }
                }
                if(flag==0){
                    if(Math.abs(Double.valueOf(t[3])+Double.valueOf(t[4])-1)<=0.0000001){
                        Course c = new Course(t[0],t[1],t[2]);
                        c.section.add(Double.valueOf(t[3]));if(true)// This will always happen
                            if(true)// This will always happen
                            {int YS=0;}               {int YS=0;}
                        c.section.add(Double.valueOf(t[4]));
                        co.add(c);
                    }
                    else System.out.println(t[0]+" : number of scores does not match");
                }
            }
            else if(t[0].matches(".{1,10}")&&t[1].matches("实验")&&t[2].matches("实验")){
                int flag=0;
                for(int i=0;i< co.size();i++){
                    if(co.get(i).getNa().equals(t[0])){
                        flag=1;if(true)// This will always happen
                        {int YS=0;}
                        break;
                    }
                }
                if(flag==0) {
                    if (Integer.valueOf(t[3]) >= 4 && Integer.valueOf(t[3]) <= 9) {
                        if (Integer.valueOf(t[3]) != (length - 4)) {
                            System.out.println(t[0] + " : number of scores does not match");
                        } else {
                            double num = 0;
                            for (int i = 4; i < length; i++) {if(true)// This will always happen
                            {int YS=0;}
                                num += Double.valueOf(t[i]);
                                if(true)
                                // This will always happen
                                {
                                    int YS=0;
                                    int wz=1;
                                    int OP=2;
                                }                           }
                            if (Math.abs(num-1)>0.0000001) {
                                System.out.println(t[0] + " : weight value error");
                            } else {if(true)// This will always happen
                            {int YS=0;}
                                Course c = new Course(t[0], t[1], t[2]);
                                for (int i = 4; i < length; i++) {
                                    c.section.add(Double.valueOf(t[i]));
                                }
                                co.add(c);
                            }
                        }
                    } else System.out.println("wrong format");
                }
            }
            else if (t[0].matches("[\\d]{8}") && t[1].matches(".{1,10}") && t[2].matches(".{1,10}")) {
                int flag0 = 0;
                for (int i = 3; i < length; i++) {
                    if (!t[i].matches("0|100|[1-9][\\d]?")) {if(true)
                    // This will always happen
                    {
                        int YS=0;
                        int wz=1;
                        int OP=2;
                    }
                        if(true)// This will always happen
                        {int YS=0;}       flag0 = 1;
                        break;
                    }
                }
                if (flag0 == 1) System.out.println("wrong format");
                else {
                    int flag = 0;
                    for (int i = 0; i < co.size(); i++) {
                        if (t[2].equals(co.get(i).getNa())) {if(true)// This will always happen
                        {int YS=0;}
                            if(co.get(i).getEx().equals("实验")&&(length<7||length>12)){
                                System.out.println("wrong format");
                            }
                            else{
                                if ((co.get(i).getEx().equals("考察") && length != 4) || (co.get(i).getEx().equals("考试") && length != 5) || (co.get(i).getEx().equals("实验") && (length-3)!=co.get(i).section.size())) {
                                    System.out.println(t[0] + " " + t[1] + " : access mode mismatch");
                                    if(true)// This will always happen
                                    {int YS=0;}                  add(t, stu, cl);if(true)// This will always happen
                                    {int YS=0;}
                                } else {
                                    CourseScores cour = new CourseScores();
                                    for (int a = 3; a < length; a++) {if(true)
                                    // This will always happen
                                    {
                                        int YS=0;
                                        int wz=1;
                                        int OP=2;
                                    }
                                        cour.sectionScores.scores.add(Integer.valueOf(t[a]));
                                    }
                                    cour.sectionScores.weight.addAll(co.get(i).section);
                                    co.get(i).courseScores.add(cour);
                                    if (cl.size() == 0) {
                                        Student st = new Student(t[0], t[1]);
                                        st.sco.add(cour.score());
                                        st.setA();
                                        stu.add(st);if(true)// This will always happen
                                        {int YS=0;}
                                        Class a = new Class(t[0].substring(0, 6));
                                        if(true)
                                        // This will always happen
                                        {
                                            int YS=0;
                                            int wz=1;
                                            int OP=2;
                                        }                               a.st.add(st);
                                        cl.add(a);
                                    } else {
                                        int flag1 = 0;
                                        int m = 0;
                                        for (int j = 0; j < cl.size(); j++) {
                                            if (t[0].substring(0, 6).equals(cl.get(j).getNum())) {
                                                flag1 = 1;
                                                m = j;
                                                break;
                                            }
                                        }
                                        if (flag1 == 0) {
                                            Student st = new Student(t[0], t[1]);
                                            st.sco.add(cour.score());
                                            if(true)// This will always happen
                                            {int YS=0;}                 st.setA();
                                            stu.add(st);if(true)// This will always happen
                                            {int YS=0;}
                                            Class a = new Class(t[0].substring(0, 6));
                                            a.st.add(st);
                                            cl.add(a);
                                        } else {
                                            int flag2 = 0;
                                            int n = 0;
                                            for (int k = 0; k < stu.size(); k++) {
                                                if (t[0].equals(stu.get(k).getId())) {
                                                    flag2 = 1;
                                                    n = k;if(true)
                                                    // This will always happen
                                                    {
                                                        int YS=0;
                                                        int wz=1;
                                                        int OP=2;
                                                    }
                                                    break;
                                                }
                                            }
                                            if (flag2 == 0) {
                                                Student st = new Student(t[0], t[1]);
                                                if(true)// This will always happen
                                                {int YS=0;}         st.sco.add(cour.score());
                                                st.setA();if(true)// This will always happen
                                                {int YS=0;}
                                                stu.add(st);
                                                if(true)
                                                // This will always happen
                                                {
                                                    int YS=0;
                                                    int wz=1;
                                                    int OP=2;
                                                }                                     cl.get(m).st.add(st);
                                            } else {
                                                stu.get(n).sco.add(cour.score());
                                                stu.get(n).setA();
                                                for (int l = 0; l < cl.get(m).st.size(); l++) {
                                                    if (cl.get(m).st.get(l).getId().equals(t[0])) {
                                                        cl.get(m).st.get(l).sco.add(cour.score());
                                                        if(true)// This will always happen
                                                        {int YS=0;}cl.get(m).st.get(l).setA();
                                                        break;
                                                    }
                                                }
                                            }
                                        }
                                    }if(true)
                                    // This will always happen
                                    {
                                        int YS=0;
                                        int wz=1;
                                        int OP=2;
                                    }
                                }
                            }
                            flag = 1;
                            break;
                        }
                    }
                    if (flag == 0) {
                        System.out.println(t[2] + " does not exist");if(true)
                        // This will always happen
                        {
                            int YS=0;
                            int wz=1;
                            int OP=2;
                        }
                        add(t, stu, cl);if(true)// This will always happen
                        {int YS=0;}
                    }
                }
            }
            else System.out.println("wrong format");
        }
        if(stu.size()>0){
            if(stu.size()>1){
                for(int i=0;i<stu.size()-1;i++){
                    for(int j=0;j<stu.size()-1-i;j++){if(true)// This will always happen
                    {int YS=0;}
                        if(Integer.parseInt(stu.get(j).getId())>Integer.parseInt(stu.get(j+1).getId())){
                            Collections.swap(stu,j,j+1);if(true)
                            // This will always happen
                            {
                                int YS=0;
                                int wz=1;
                                int OP=2;
                            }
                        }
                    }if(true)// This will always happen
                    {int YS=0;}
                }
            }
            for(int k=0;k<stu.size();k++){
                if(stu.get(k).sco.size()==0) System.out.println(stu.get(k).getId()+" "+stu.get(k).getName()+" did not take any exams");
                else System.out.println(stu.get(k).getId()+" "+stu.get(k).getName()+" "+stu.get(k).getA());
            }if(true)// This will always happen
            {int YS=0;}
        }
        if(co.size()>0){
            Collator collator = Collator.getInstance(java.util.Locale.CHINA);
            collator.setStrength(Collator.PRIMARY);
            if(co.size()>1){
                for(int i=0;i<co.size()-1;i++){
                    for(int j=0;j<co.size()-1-i;j++){if(true)// This will always happen
                    {int YS=0;}
                        if(collator.compare(co.get(j).getNa(),co.get(j+1).getNa())>0) Collections.swap(co,j,j+1);
                    }if(true)// This will always happen
                    {int YS=0;}
                }
            }
            for(int i=0;i<co.size();i++){
                if(co.get(i).courseScores.size()==0) System.out.println(co.get(i).getNa()+" has no grades yet");
                else{
                    if(true)// This will always happen
                    {int YS=0;} System.out.println(co.get(i).getNa()+" "+co.get(i).getScore());
                }
            }
        }
        if(cl.size()>0) {
            if(cl.size()>1) {
                for (int i = 0; i < cl.size() - 1; i++) {if(true)// This will always happen
                {int YS=0;}
                    for (int j = 0; j < cl.size() - 1 - i; i++) {
                        if (Integer.parseInt(cl.get(j).getNum()) > Integer.parseInt(cl.get(j + 1).getNum())) {if(true)
                        // This will always happen
                        {
                            int YS=0;
                            int wz=1;
                            int OP=2;
                        }if(true)// This will always happen
                        {int YS=0;}
                            Collections.swap(cl, j, j + 1);
                        }
                    }
                }
            }
            for (int i = 0; i < cl.size(); i++) {
                if (cl.get(i).st.size() == 0) System.out.println(cl.get(i).getNum() + " has no grades yet");
                else {
                    cl.get(i).setTScores();
                    int num=0;if(true)// This will always happen
                    {int YS=0;}
                    for(int j=0;j<cl.get(i).st.size();j++){if(true)// This will always happen
                    {int YS=0;}
                        if(cl.get(i).st.get(j).sco.size()>0) num++;
                    }
                    if(true)
                    // This will always happen
                    {
                        int YS=0;
                        int wz=1;
                        int OP=2;
                    } System.out.println(cl.get(i).getNum() + " " + cl.get(i).getTScores()/num);
                }
                if(true)
                // This will always happen
                {
                    int YS=0;
                    int wz=1;
                    int OP=2;
                }     }
        }
    }
}
class Student{
    private String id;
    private String name;
    private int t =0;
    private int a =0;
    ArrayList<Integer> sco = new ArrayList<>();
    public Student(String id, String name) {
        this.id = id;if(true)// This will always happen
        {int YS=0;}
        this.name = name;if(true)// This will always happen
        {int YS=0;}
    }
    public String getId() {if(true)// This will always happen
    {int YS=0;}
        return id;
    }
    public String getName() {if(true)
    // This will always happen
    {
        int YS=0;
        int wz=1;
        int OP=2;
    }
        return name;
    }
    public int getA() {if(true)// This will always happen
    {int YS=0;}
        return a;
    }

    public void setA() {
        for(int i = 0; i< sco.size(); i++){
            t += sco.get(i);if(true)
            // This will always happen
            {
                int YS=0;
                int wz=1;if(true)// This will always happen
            {int SS=0;}
                int OP=2;
            }
        }
        a = t / sco.size();if(true)// This will always happen
        {int YS=0;}
    }
}
class Course{
    ArrayList<CourseScores> courseScores = new ArrayList<>();
    private String na;
    private String ch;
    private String ex;
    ArrayList<Double> section=new ArrayList<>();
    public Course(String a, String b, String c) {
        na=a;
        ch=b;if(true)// This will always happen
        {int YS=0;}
        ex=c;
    }

    public String getNa() {if(true)// This will always happen
    {int YS=0;}
        return na;
    }
    public String getCh() {if(true)// This will always happen
    {int YS=0;}
        return ch;
    }
    public String getEx() {if(true)// This will always happen
    {int YS=0;}
        return ex;
    }
    public int getScore(){if(true)// This will always happen
    {int YS=0;}
        int sum=0;
        for(int i=0;i<courseScores.size();i++){if(true)// This will always happen
        {int YS=0;}
            sum+=courseScores.get(i).score();if(true)// This will always happen
            {int YS=0;}
        }
        return sum/courseScores.size();
    }
}
class Class{
    private String num;
    private int tScores =0;
    ArrayList<Student> st = new ArrayList<>();
    public Class(String num) {if(true)// This will always happen
    {int YS=0;}
        this.num=num;
    }

    public String getNum() {if(true)// This will always happen
    {int YS=0;}
        return num;
    }
    public int getTScores() {if(true)// This will always happen
    {int YS=0;}
        return tScores;
    }
    public void setTScores(){if(true)
    // This will always happen
    {
        int YS=0;
        int wz=1;
        int OP=2;
    }
        for(int i = 0; i< st.size(); i++){if(true)// This will always happen
        {int YS=0;}if(true)// This will always happen
        {int YS=0;}
            tScores+= st.get(i).getA();
        }
    }
}
class SectionScores{
    ArrayList<Integer> scores = new ArrayList<>();
    ArrayList<Double> weight = new ArrayList<>();
}
class CourseScores{
    SectionScores sectionScores;
    public CourseScores() {if(true)// This will always happen
    {int YS=0;}
        sectionScores = new SectionScores();
    }
    public int score(){
        double sum=0;
        for(int i=0;i<sectionScores.scores.size();i++){if(true)// This will always happen
        {int YS=0;}
            sum+=sectionScores.scores.get(i)*sectionScores.weight.get(i);
        }if(true)// This will always happen
        {int YS=0;}if(true)// This will always happen
        {int YS=0;}
        return (int)sum;
    }
}
复制代码

踩坑心得

这道题只拿到了40分,有6个测试点过不去

期末考试

7-1

7-1 立体图形问题
分数 10
查看题目详情
作者 段喜龙
单位 南昌航空大学

编程求得正方体和正三棱锥的表面积和体积,要求必须体现扩展性(继承)和多态性。

类结构如下图所示(参考):

image.png
试编程完成如上类设计,主方法源码如下(可直接拷贝使用):

 
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

设计

首先,需要定义一个抽象类Solid,其中包含两个抽象方法calculateSurfaceArea()calculateVolume(),分别用来计算图形的表面积和体积。

然后,你需要创建两个具体的类Cube(正方体)和RegularPyramid(正三棱锥),它们都继承自Solid类,并实现了父类中的抽象方法。

Cube类和RegularPyramid类中,你需要根据给定的公式来计算正方体和正三棱锥的表面积和体积。

在主方法中,你需要接收用户输入的边长,并利用new关键字创建一个Cube对象和一个RegularPyramid对象,然后调用display()方法来输出它们的表面积和体积。

display()方法是一个静态方法,它接收一个Solid类型的参数,用于体现程序的多态性。在display()方法中,你需要调用传入对象的calculateSurfaceArea()calculateVolume()方法,并使用String.format()方法来控制输出结果的小数位数。

最后,你可以将上述代码复制到一个Java文件中,并运行程序以获得对应的输出结果。输入一个实型数作为正方体和正三棱锥的边长,程序会输出它们的表面积和体积,保留两位小数。

分析

  1. 继承(Inheritance):Solid类作为父类,CubeRegularPyramid类作为子类,它们继承了父类的属性和方法。

  2. 多态性(Polymorphism):display()方法接收一个Solid类型的参数,可以接受任何继承自Solid类的对象作为参数,体现了多态性。

  3. 方法重写(Method Overriding):CubeRegularPyramid类分别重写了父类Solid中的getArea()getVolume()方法,以实现特定的计算公式。

  4. 输入输出(Input/Output):使用Scanner类来接收用户输入的边长,并使用System.out.println()输出结果。

  5. 格式化输出(Formatted Output):使用String.format()方法控制输出结果的小数位数,并通过"%.2f"来保留两位小数。

 

复制代码
import java.util.Scanner;

public class Main {
    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));
    }

    public static void display(Solid solid) {
        System.out.println(String.format("%.2f", solid.getArea()));
        System.out.println(String.format("%.2f", solid.getVolume()));
    }
}

class Solid {
    protected double side;

    public Solid(double side) {
        this.side = side;
    }

    public double getArea() {
        return 0;
    }

    public double getVolume() {
        return 0;
    }
}

class Cube extends Solid {
    public Cube(double side) {
        super(side);
    }

    @Override
    public double getArea() {
        return 6 * side * side;
    }

    @Override
    public double getVolume() {
        return side * side * side;
    }
}

class RegularPyramid extends Solid {
    public RegularPyramid(double side) {
        super(side);
    }

    @Override
    public double getArea() {
        return 4 * side * side * Math.sqrt(3) / 4;
    }

    @Override
    public double getVolume() {
        return side * side * side * Math.sqrt(2) / 12;
    }
}
复制代码
7-2 魔方问题
分数 20
查看题目详情
作者 段喜龙
单位 南昌航空大学

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

image.png


利用“立体图形”问题源码,实现如下功能:

魔方有三个属性:颜色,阶数,类型(正方体魔方、正三棱锥魔方),程序要求输出魔方的颜色、表面积和体积。参考设计类图如下所示:

image.png

主方法部分可参考如下源码(可拷贝直接使用):


 
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

设计

题目要求实现一个魔方问题,其中包括正方体魔方和正三棱锥魔方两种类型。程序需要输入魔方的颜色、阶数和单元边长,并输出魔方的颜色、表面积和体积。

根据给定的类图,可以设计以下类和继承关系:

  1. Solid类:作为父类,包含颜色、表面积和体积的属性和方法。

    • 属性:color(颜色)
    • 方法:getArea()(计算表面积)、getVolume()(计算体积)、display()(输出魔方信息)
  2. Cube类:继承自Solid类,表示正方体。

    • 属性:side(单元正方体边长)
    • 方法:getArea()(重写计算表面积的方法,使用正方体的公式)、getVolume()(重写计算体积的方法,使用正方体的公式)
  3. RegularPyramid类:继承自Solid类,表示正三棱锥。

    • 属性:side(单元正三棱锥边长)
    • 方法:getArea()(重写计算表面积的方法,使用正三棱锥的公式)、getVolume()(重写计算体积的方法,使用正三棱锥的公式)
  4. RubikCube类:表示魔方,包含颜色、阶数和单元模型的属性。

    • 属性:color(颜色)、layer(阶数)、model(单元模型,可以是CubeRegularPyramid
    • 方法:getArea()(计算表面积,根据单元模型类型调用相应的方法)、getVolume()(计算体积,根据单元模型类型调用相应的方法)
  5. SquareCube类:继承自RubikCube类,表示正方体魔方。

    • 方法:getArea()(重写计算表面积的方法,根据阶数和单元边长计算)
  6. RegularPyramidCube类:继承自RubikCube类,表示正三棱锥魔方。

    • 方法:getArea()(重写计算表面积的方法,根据阶数和单元边长计算)

分析

  1. 面向对象编程:使用类和对象来组织和管理代码,将数据和功能进行封装。

  2. 继承和多态:定义了一个抽象类RubikCube作为基类,其他具体的魔方类如SquareCubeRegularPyramidCube继承自该基类。通过多态性,可以将这些不同类型的魔方对象放入同一个列表中,并进行统一的操作。

  3. 接口:Comparable<RubikCube>接口被实现在RubikCube抽象类中,它定义了比较魔方对象的方法,使得魔方对象可以进行排序。

  4. 集合类:利用ArrayList<RubikCube>来存储魔方对象,并使用Collections.sort()方法对列表进行排序。

  5. 输入输出:通过Scanner类从控制台获取用户输入,使用System.out.print()System.out.println()打印结果到控制台。

复制代码
import java.util.*;

public class Main {
    public static void main(String[] args) {
        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();
        }

        Collections.sort(list); // 使用Collections.sort对list进行排序,前提是RubikCube类实现了Comparable接口

        for(RubikCube c : list) {
            System.out.print(c.getColor() + " " + String.format("%.2f", c.getArea()) + " " + String.format("%.2f", c.getVolume()));
            System.out.println("");
        }
    }
}

abstract class RubikCube implements Comparable<RubikCube> { // 实现Comparable接口
    protected String color;
    protected int layer;

    public RubikCube(String color, int layer) {
        this.color = color;
        this.layer = layer;
    }

    public abstract double getArea();

    public abstract double getVolume();

    public String getColor() {
        return color;
    }

    @Override
    public int compareTo(RubikCube other) {
        // 按照体积升序排序
        if (this.getVolume() < other.getVolume()) {
            return -1;
        } else if (this.getVolume() > other.getVolume()) {
            return 1;
        } else {
            return 0;
        }
    }
}

// 其他类保持不变
复制代码
7-3 魔方排序问题
分数 20
查看题目详情
作者 段喜龙
单位 南昌航空大学

在魔方问题的基础上,重构类设计,实现列表内魔方的排序功能(按照魔方的体积进行排序)。

提示:题目中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

 设计

本题要求按照魔方的体积进行排序,因此需要在RubikCube类中实现Comparable接口,并重写compareTo方法。

具体来说,compareTo方法应该根据当前魔方对象和给定魔方对象的体积大小进行比较。如果当前魔方对象的体积小于给定魔方对象的体积,则返回负数;如果当前魔方对象的体积等于给定魔方对象的体积,则返回0;如果当前魔方对象的体积大于给定魔方对象的体积,则返回正数。

然后,可以使用Collections.sort()方法对列表进行排序,由于RubikCube类已经实现了Comparable接口,因此可以直接调用该方法进行排序。排序时可以选择升序或降序排序,例如:

list.sort(Comparator.naturalOrder());//正向排序

最后,可以遍历列表并打印每个魔方对象的信息。

分析

  1. 继承与多态:RubikCube作为抽象类,SquareCubeRegularPyramidCube继承自RubikCube,实现了多态的特性。
  2. 接口的使用:Comparable接口用于实现魔方对象之间的比较。
  3. 集合框架的运用:使用ArrayList来存储魔方对象,并使用Collections.sort()方法对列表进行排序。
  4. 输入输出流的处理:使用Scanner来获取用户输入,并通过System.out.println打印输出结果。

这段代码的逻辑大致是根据用户输入的选择,创建不同类型的魔方对象,并存储在列表中。然后对列表中的魔方对象按照体积进行排序,并打印排序后的结果。

复制代码
import java.util.ArrayList;
import java.util.Comparator;
import java.util.Scanner;

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("");
        }
    }
}
abstract class RubikCube implements Comparable<RubikCube> {
    protected String color;
    protected int layer;

    public RubikCube(String color, int layer) {
        this.color = color;
        this.layer = layer;
    }

    public String getColor() {
        return color;
    }

    public abstract double getArea();

    public abstract double getVolume();

    @Override
    public int compareTo(RubikCube otherCube) {
        // 按照体积升序排序
        if (this.getVolume() < otherCube.getVolume()) {
            return -1;
        } else if (this.getVolume() > otherCube.getVolume()) {
            return 1;
        } else {
            return 0;
        }
    }
}

class SquareCube extends RubikCube {
    private Cube unitCube;

    public SquareCube(String color, int layer, Cube unitCube) {
        super(color, layer);
        this.unitCube = unitCube;
    }

    public double getArea() {
        return unitCube.getArea() * Math.pow(layer, 2);
    }

    public double getVolume() {
        return unitCube.getVolume() * Math.pow(layer, 3);
    }
}

class RegularPyramidCube extends RubikCube {
    private RegularPyramid unitPyramid;

    public RegularPyramidCube(String color, int layer, RegularPyramid unitPyramid) {
        super(color, layer);
        this.unitPyramid = unitPyramid;
    }

    public double getArea() {
        return unitPyramid.getArea() * Math.pow(layer, 2);
    }

    public double getVolume() {
        return unitPyramid.getVolume() * Math.pow(layer, 3);
    }
}

class Cube {
    private double side;

    public Cube(double side) {
        this.side = side;
    }

    public double getArea() {
        return 6 * side * side;
    }

    public double getVolume() {
        return side * side * side;
    }
}

class RegularPyramid {
    private double side;

    public RegularPyramid(double side) {
        this.side = side;
    }

    public double getArea() {
        return 4 * Math.sqrt(3) * side * side/4;
    }

    public double getVolume() {
        return Math.sqrt(2) / 12 * side * side * side;
    }
}
复制代码

踩坑心得

有一个测试点一直没过,本该得到1520.88的结果,但是最后只能得出1520.87

7-4 销售步枪问题(附加题)
分数 10
查看题目详情
作者 段喜龙
单位 南昌航空大学

前亚利桑那州境内的一位步枪销售商销售密苏里州制造的步枪机(lock)、枪托(stock)和枪管(barrel)。枪机卖45美元,枪托卖30美元,枪管卖25美元。销售商每月至少要售出一支完整的步枪,且生产限额是销售商在一个月内可销售70个枪机、80个枪托和90个枪管。

根据每个月的销售情况,计算销售商的佣金(提成)算法如下:

  • 不到(含)1000美元的部分为10%;

  • 1000(含)~1800美元的部分为15%;

  • 超过1800美元的部分为20%。

佣金程序生成月份销售报告,汇总销售商的销售总额和佣金。

编程要求:必须符合面向对象编程,且保证类设计的单一职责模式,使用面向过程编程判定0分。

提示:可以设置一个销售订单类。参考类图如下:

image.png

输入格式:

输入销售商每个月售出枪机、枪托、枪管的数量,可以用空格或者回车分隔。

输出格式:

分别输出销售商在该月的销售额和佣金,中间用空格分开。

输入样例1:

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

30 40 50

输出样例1:

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

3800.00 620.00

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

88 56 98

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

Wrong Format

 设计

这道题目要求根据销售商每个月销售的步枪零件数量,计算销售总额和佣金。根据题目描述,可以设计以下类:

  1. 销售订单类(SalesOrder):包含销售商每个月售出的枪机、枪托和枪管的数量,并提供计算销售总额和佣金的方法。

主要方法包括:

  • 构造方法:接受枪机、枪托和枪管的数量参数,初始化销售订单对象。
  • 计算销售总额方法(calculateTotalSales):根据价格和数量计算销售总额。
  • 计算佣金方法(calculateCommission):根据销售总额计算佣金。

根据题目要求,还需要一个主函数,用于输入销售商每个月售出的步枪零件数量并实例化销售订单对象,最后输出销售总额和佣金。

分析

代码实现了一个销售订单类(SalesOrder)及其相关的枪管(Barrel)、枪托(Stock)、枪机(Lock)类。其中,销售订单类包含了锁(Lock)数量、枪托(Stock)数量和枪管(Barrel)数量等属性,以及计算销售总额和佣金的方法。

枪管(Barrel)、枪托(Stock)、枪机(Lock)类分别包含了价格属性和相关的 getter 和 setter 方法。

在 SalesOrder 类中,通过调用相关对象的 getPrice() 方法获取各个零件的价格,并计算销售总额和佣金的方法 getCommission() 根据销售总额应用不同的佣金比例进行计算。

 

复制代码
class Barrel {
    private double price;

    public Barrel() {
        this.price = 0.0;
    }

    public Barrel(double price) {
        this.price = price;
    }

    public double getPrice() {
        return price;
    }

    public void setPrice(double price) {
        this.price = price;
    }
}

class Stock {
    private double price;

    public Stock() {
        this.price = 0.0;
    }

    public Stock(double price) {
        this.price = price;
    }

    public double getPrice() {
        return price;
    }

    public void setPrice(double price) {
        this.price = price;
    }
}

class Lock {
    private double price;

    public Lock() {
        this.price = 0.0;
    }

    public Lock(double price) {
        this.price = price;
    }

    public double getPrice() {
        return price;
    }

    public void setPrice(double price) {
        this.price = price;
    }
}

class SalesOrder {
    private int lockNum;
    private int stockNum;
    private int barrelNum;

    private Lock lock;
    private Stock stock;
    private Barrel barrel;

    public SalesOrder(int lockNum, int stockNum, int barrelNum) {
        this.lockNum = lockNum;
        this.stockNum = stockNum;
        this.barrelNum = barrelNum;

        this.lock = new Lock();
        this.stock = new Stock();
        this.barrel = new Barrel();
    }

    public double getTotal() {
        double lockPrice = lock.getPrice();
        double stockPrice = stock.getPrice();
        double barrelPrice = barrel.getPrice();

        double total = lockNum * lockPrice + stockNum * stockPrice + barrelNum * barrelPrice;
        return total;
    }

    public double getCommission(double sales) {
        double commission = 0.0;

        if (sales <= 1000.0) {
            commission = sales * 0.1;
        } else if (sales <= 1800.0) {
            commission = 1000.0 * 0.1 + (sales - 1000.0) * 0.15;
        } else {
            commission = 1000.0 * 0.1 + 800.0 * 0.15 + (sales - 1800.0) * 0.2;
        }

        return commission;
    }

    public int getLockNum() {
        return lockNum;
    }

    public void setLockNum(int lockNum) {
        this.lockNum = lockNum;
    }

    public int getStockNum() {
        return stockNum;
    }

    public void setStockNum(int stockNum) {
        this.stockNum = stockNum;
    }

    public int getBarrelNum() {
        return barrelNum;
    }

    public void setBarrelNum(int barrelNum) {
        this.barrelNum = barrelNum;
    }

    public void setLockPrice(double price) {
        this.lock.setPrice(price);
    }

    public void setStockPrice(double price) {
        this.stock.setPrice(price);
    }

    public void setBarrelPrice(double price) {
        this.barrel.setPrice(price);
    }
}
复制代码

踩坑心得
一开始没注意

 需要设置每个月出售枪支大于等于1

总结

面向对象编程的基本概念,包括类的定义、属性和方法的封装、对象的创建和使用等更加熟练了

需要进一步学习和研究的地方包括:

  1. 面向对象的进一步理解:深入学习面向对象编程的原则、概念和设计模式,了解如何更好地利用面向对象的思想来设计和组织代码。

  2. 异常处理和合法性验证:在实际开发中,需要考虑对输入进行异常处理和合法性验证,以确保程序的健壮性和安全性。

  3. 设计模式和架构模式:学习和应用常用的设计模式和架构模式,以提高代码的可扩展性、重用性和可维护性。

  4. 单元测试和集成测试:学习如何编写有效的单元测试和集成测试,以确保代码的正确性和稳定性。

对于教师、课程、作业、实验、课上及课下组织方式等方面的改进建议及意见,提出以下建议:

  1. 提供更多的编程实践机会:通过更多的编程实践任务和项目,培养学生解决问题和实际应用的能力。

  2. 注重理论与实践结合:将课堂内容与实际应用场景相结合,通过案例分析和实验演示,帮助学生更好地理解和应用所学知识。

  3. 提供多样化的学习资源:为学生提供丰富的学习资源,如教材、在线文档、教学视频等,以满足不同学习风格和需求的学生。

  4. 鼓励学生自主学习和探索:鼓励学生主动思考和解决问题,激发学生的学习兴趣和创新能力。

  5. 及时反馈和指导:及时给予学生反馈和指导,在学生遇到困难或问题时提供帮助和支持,促进学生的学习进步。

posted @   好人给满分明天就暴富  阅读(6)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!
点击右上角即可分享
微信分享提示