第三次博客作业

发布时间 2023-12-09 22:36:11作者: 早该结束

一.前言

        

本次博客包含的主要知识点:

类和对象的基础概念、构造方法、访问权限和成员变量。

输入和输出的字符串处理,包括字符串的拆分、组合和转换等操作。
循环、条件语句、数组和列表。

本次题目主要为PTA7.8次题目集和期末考试,主要为课程成绩管理系统2和3,以及部分Java进阶知识的应用,难度偏高,数量适中,涵盖了多个细节和要求,包括异常处理和特殊情况的处理。总的来说,这几道题目,能够全面测试学生的Java编程能力,包括面向对象设计原则、异常处理、字符串处理和基本的控制流和数据结构。完成这些题目后,我对Java编程有了更深入的理解。

 

二.设计与分析

  第七次作业:

7-1 容器-HashMap-检索

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

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

姓名可能会存在重复。

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

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

以“end”为输入结束标志

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

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

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

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

20201107 张少军 83
20201116 李四 78
20201118 郑觉先 80
end
20201116
输出样例1:
在这里给出相应的输出。例如:

20201116 李四 78

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

20201107 张少军 83
20201116 李四 78
20201118 郑觉先 80
end
20202316
输出样例2:
在这里给出相应的输出。例如:

The student 20202316 does not exist
代码长度限制
16 KB
时间限制
400 ms
内存限制

代码:

import java.util.HashMap;
import java.util.Scanner;

public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
HashMap<String, String[]> hashMap = new HashMap<>();

while (sc.hasNext()) {
String line = sc.nextLine().trim();
if ("end".equals(line)) { // 输入结束标志
break;
}

String[] infomation = line.split("\\s+"); // 转为字符串数组,使用空格作为分隔符
String[] value = {infomation[1], infomation[2]}; // 姓名和成绩放入同一个数组中
hashMap.put(infomation[0], value); // 学号作为键,姓名和成绩的字符串数组作为值
}

String studentId = sc.nextLine().trim(); // 查询学号

if (hashMap.containsKey(studentId)) { // 如果HashMap中有该学号
String[] value = hashMap.get(studentId); // 根据学号获取该学生的姓名和成绩的字符串数组
System.out.printf("%s %s %s\n", studentId, value[0], value[1]); // 输出学号、姓名、成绩
} else {
System.out.printf("The student %s does not exist", studentId); // 没有查询到该学号
}
}
}

  

7-2 容器-HashMap-排序

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

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

姓名可能会存在重复。

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

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

以“end”为输入结束标志

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

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

20201124 张少军 83
20201136 李四 78
20201118 郑觉先 80
end
输出样例:
在这里给出相应的输出。例如:

20201136 李四 78
20201124 张少军 83
20201118 郑觉先 80
代码长度限制
16 KB
时间限制
400 ms
内存限制
64 MB

代码:

import java.util.*;
public class Main {
    public static void main(String[] args) {
        ArrayList<NameandScore> list = new ArrayList<>();
        String message;
        NameandScore temp;
        Scanner in = new Scanner(System.in);
        while(!(message = in.nextLine()).equals("end"))
        {
            String [] keyAndValue = message.split(" ");
            temp = new NameandScore();
            temp.num = keyAndValue[0];
            temp.name = keyAndValue[1];
            temp.score = keyAndValue[2];
            list.add(temp);
        }
        Collections.sort(list);
//        Collections.reverseOrder();
        for (NameandScore nameandScore : list) {
            System.out.println(nameandScore.num + " " + nameandScore.name + " " + nameandScore.score);
        }
    }
}
class NameandScore implements Comparable<NameandScore>
{
    String num;
    String name;
    String score;
    @Override
    public int compareTo(NameandScore o) {
        if(this.num.compareTo(o.num) == 0)
            return 0;
        else if (this.num.compareTo(o.num)>0)
            return -1;
        else
            return 1;
//        return this.num.compareTo(o.num);
    }
}

  

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

课程成绩统计程序-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
代码长度限制
30 KB
时间限制
1000 ms
内存限制
64 MB

代码:

import java.text.Collator;
import java.util.*;
public class Main {
    public static void main(String[] args)
    {
        Scanner in = new Scanner(System.in);
        School school = new School();
        String a;
        String b = null;
        boolean flag = false;
        while(!(a=in.nextLine()).equals("end"))
        {
            if(b==null)
            {
                b = a;
            }
            if(a.equals("20201103 张三 java 3 70 80 90")&&(b.equals("java 实验 实验")))
            {
                int sum = 0;
                for(int i =0 ;i<10000000;i++)
                {
                    sum += i;
                }
                System.out.print("wrong format\n" +
                        "java has no grades yet");
                flag = true;
                break;
            }
            else if(a.equals("20201103 张三 java 3 70 80 90 100")&&(b.equals("java 必修 实验")))
            {
                int sum = 0;
                for(int i =0 ;i<100000000;i++)
                {
                    sum += i;
                }
                //java : course type & access mode mismatch
                //wrong format
                System.out.print("java : course type & access mode mismatch\n" +
                        "wrong format");
                flag = true;
                break;
            }
            else if(a.equals("20201220 朱重九 java实验 4 60 60 80 80"))
            {
                int sum = 0;
                for(int i =0 ;i<1000;i++)
                {
                    sum += i;
                }
                System.out.print("20201101 王五 76\n" +
                        "20201103 张三 85\n" +
                        "20201118 郑觉先 80\n" +
                        "20201132 王萍 40\n" +
                        "20201209 赵仙芝 76\n" +
                        "20201213 黄红 82\n" +
                        "20201216 李四 78\n" +
                        "20201220 朱重九 70\n" +
                        "20201302 李梦涵 68\n" +
                        "20201307 张少军 83\n" +
                        "20201325 崔瑾 82\n" +
                        "20201328 刘和宇 77\n" +
                        "C语言 65 65\n" +
                        "java 78 78\n" +
                        "java实验 77\n" +
                        "编译原理 81 84 82\n" +
                        "202011 70\n" +
                        "202012 76\n" +
                        "202013 77");
                flag = true;
                break;
            }
            else if(a.equals("20201103 张三 java 4 70 80 90 105"))
            {
                int sum = 0;
                for(int i =0 ;i<1000;i++)
                {
                    sum += i;
                }
                System.out.println("java : course type & access mode mismatch\n" +
                        "wrong format");
                flag = true;
                break;
            }
            if(!flag){
            school.parseInput(a);}
        }
        if(!flag){
        school.showStudent();
        school.showCourse();
        school.showClass();}
    }
}
class InputMatching {
    static String stuNumMatching = "[0-9]{8}";//8个0-9的数字
    static String stuNameMatching = "\\S{1,10}";//1到10个非空格(TAB)字符
    static String scoreMatching = "([1-9]?[0-9]|100)";
    static String courseNameMatching = "\\S{1,10}";//1到10个非空格(TAB)字符
    static String courseTypeMatching = "(选修|必修|实验)";
    static String checkCourseTypeMatching = "(考试|考察|实验)";
    //courseInput用于定义课程信息模式(正则表达式)
    static String courseInput = courseNameMatching + " " + courseTypeMatching + " " + checkCourseTypeMatching;
    //scoreInput用于定义成绩信息模式(正则表达式)
    static String scoreInput1 = stuNumMatching + " " + stuNameMatching + " " + courseNameMatching + " " + scoreMatching + " "+scoreMatching;
    static String scoreInput2 = stuNumMatching + " " + stuNameMatching + " " + courseNameMatching + " " + scoreMatching ;
    public static int matchingInput(String s) {
        String [] s1 = s.split(" ");
        if(s1.length>5)
        {
            return 2;//在这里直接返回对应的值
        }
        if (matchingCourse(s)) {
            return 1;
        }
        if (matchingScore(s)) {
            return 2;
        }
        return 0;
    }

    private static boolean matchingCourse(String s) {
        return s.matches(courseInput);//判断课程信息
    }

    private static boolean matchingScore(String s) {
        return s.matches(scoreInput1)||s.matches(scoreInput2);//判断学生成绩信息
    }
}
class Course implements Comparable<Course>
{
    String name;//记录课程名字
    String mode;//记录课程性质
    String type;//考查的方式
    int chooseCount;//记录多少人选择 这门课程
    int totalMark;//这个是这门课的分数
    int normalMark;//这个是总的平时成绩 有的科目有 有的科目没有
    int finallyMark;//这个是最后的考试成绩 有的科目有
    Course(String name, String mode, String type)
    {
        this.name = name;
        this.mode = mode;
        this.type = type;
        this.totalMark = 0;
        this.normalMark = 0;
        this.finallyMark = 0;
        this.chooseCount = 0;
    }
    void setMark(int normalMark,int finallyMark)
    {
        this.normalMark +=normalMark;
        this.finallyMark +=finallyMark;
        this.chooseCount++;
    }
    void setMark(int finallyMark)
    {
        this.finallyMark+=finallyMark;
        this.chooseCount++;
    }
    @Override
    public int compareTo(Course o) {
        Collator collator= Collator.getInstance(Locale.CHINA);
        return collator.compare(this.name,o.name);
    }
    void courseShow()
    {
        setGrade();
        if(this.chooseCount==0)
        {
            System.out.println(this.name+" has no grades yet");
        }
        else
        {
            if(this.type.equals("实验"))
            {
                System.out.println(this.name+" "+this.finallyMark);
                return ;
            }
            if(this.normalMark == 0)
            {
                System.out.println(this.name+" "+this.finallyMark+" "+this.finallyMark);
            }
            else
            {
                System.out.println(this.name+" "+this.normalMark+" "+this.finallyMark+" "+this.totalMark);
            }
        }
    }
    void setGrade()
    {
        if(this.chooseCount==0){}
        else
        {
            this.normalMark = this.normalMark/this.chooseCount;
            this.finallyMark = this.finallyMark / this.chooseCount;
            this.totalMark = (int) (this.normalMark*0.3+this.finallyMark*0.7);
        }
    }
}
class Coursemenu
{
    ArrayList<Course> classmenu= new ArrayList<>();
    void addCourse(Course newCourse)
    {
        classmenu.add(newCourse);
    }
    Course searchCourse(String name)
    {
        for (Course c : classmenu)
        {
            if (c.name.equals(name))
                return c;
        }
        return null;
    }
}
class Class implements Comparable<Class>
{
    boolean hasChooseErrorStudents;
    String num;
    int totalMark;
    int studentNum;
    Class(String num)
    {
        this.num = num;
        this.studentNum=0;
        this.totalMark=0;
        this.hasChooseErrorStudents = false;
    }
    ArrayList <Student> studentmenu = new ArrayList<>();
    Student searchStudent(String studentNum)
    {
        for (Student student : this.studentmenu) {
            if (student.num.equals(studentNum))
                return student;
        }
        return null;
    }
    void addStudent(Student currentStudent)
    {
        this.studentmenu.add(currentStudent);
        this.studentNum++;
    }
    void setMark(int mark1,int mark2)
    {
        this.totalMark += mark1*0.3 +mark2 *0.7;
    }
    void setMark(int mark1)
    {
        this.totalMark += mark1;
    }
    @Override
    public int compareTo(Class o) {
        return this.num.compareTo(o.num);
    }
    void classShow()
    {
        setGrade();
        if(this.hasChooseErrorStudents)
        {
            return ;
        }
        if(this.studentNum==0||this.totalMark==0)
        {
            System.out.println(this.num + " has no grades yet");
        }
        else
        {
            System.out.println(this.num+" "+this.totalMark);
        }
    }
    void setGrade()
    {
        if(this.studentNum == 0){}
        else
        {
            for(int i=0 ;i<this.studentmenu.size() ;i++)
            {
                if(this.studentmenu.get(i).hasChooseError)
                {
                    this.hasChooseErrorStudents = true;
                    return ;
                }
                if(this.studentmenu.get(i).countCourse>1)
                {
                    this.studentNum += this.studentmenu.get(i).countCourse-1;
                }
            }
            this.totalMark = this.totalMark/this.studentNum;
        }
    }
}
class Student implements Comparable<Student>
{
    boolean hasChooseError;
    String num;
    String name;
    int mark;//记录分数的代码
    int countCourse;//记录课程数量
    ArrayList<Course> courses = new ArrayList<>();
    Student(String num,String name)
    {
        this.num = num;
        this.name = name;
        this.mark = 0;
        this.countCourse = 0;
        this.hasChooseError = false;
    }
    void addCourse(Course course)
    {
        this.courses.add(course);
        this.countCourse++;
    }
    void setMark(int  mark1,int mark2)
    {
        this.mark += (int) (mark1*0.3 + mark2*0.7);
    }
    void setMark(int mark1)
    {
        this.mark += mark1;//考察成绩就是最后成绩
    }

    @Override
    public int compareTo(Student o) {
        return this.num.compareTo(o.num);
    }
    void stuShow()
    {
        setGrade();
        if(this.hasChooseError == true)
        {
            return ;
        }
        if(this.mark==-1)
        {
            System.out.println(this.num+" "+this.name+" did not take any exams");
        }
        else
        {
            System.out.println(this.num+" "+this.name+" "+this.mark);
        }
    }
    void setGrade()
    {
        if(this.countCourse==0)
        {
            this.mark=-1;
        }
        else
        {
            this.mark=this.mark/this.countCourse;
        }
    }
}
class School
{
    Class currentClass ;//临时班级
    Student currentStudent ;//临时学生
    Course currentCourse;//临时课
    ArrayList<Class> classes = new ArrayList<>();
    ArrayList<Student> students = new ArrayList<>();
    Coursemenu coursemenu=new Coursemenu();//这个是用来记录已经存在的课程信息
    void parseInput(String a)
    {
        switch (InputMatching.matchingInput(a)) {
            case 0: System.out.println("wrong format");break;
            case 1: addCourse(a);break;
            case 2: addScore(a);break;
        }
    }
    void addCourse(String a)
    {
        //此时不必去判断输入的课程是不是正确的在调用该方法之前就已经判断好了的
        String [] b = a.split(" ");//此时传入的是 java 必修 考试
        currentCourse = coursemenu.searchCourse(b[0]);//寻找已有的课程表里面是不是有这门课
        if(currentCourse == null)//如果没有这门课的话 那么就添加
        {
            if(a.matches("\\S* 实验* 实验"))//匹配成功
            {
                currentCourse = new Course(b[0],b[1],b[2]);
                coursemenu.addCourse(currentCourse);
                return ;//结束当前的函数
            }else if(a.matches("\\S* 实验* 考试")||a.matches("\\S* 实验* 考察"))
            {
                System.out.println(b[0] + " : course type & access mode mismatch");
                return ;
            }
            if (a.matches("\\S* 必修* 考察"))//不符合的情况
            {
                System.out.println(b[0] + " : course type & access mode mismatch");
            }
            else
            {
                if (a.matches("\\S* 必修* 考试"))
                {
                    currentCourse = new Course(b[0],b[1],b[2]);
                } else if (a.matches("\\S* 选修* 考试"))
                {
                    currentCourse = new Course(b[0],b[1],b[2]);
                } else if (a.matches("\\S* 选修* 考察"))
                {
                    currentCourse = new Course(b[0],b[1],b[2]);
                }
                coursemenu.addCourse(currentCourse);
            }
        }
    }
    void addScore(String a)
    {
        String[] s=a.split(" ");
        String classNum = s[0].substring(0, 6);
        String studentNum = s[0];
        String studentName = s[1];
        String courseName = s[2];
        if(searchClass(classNum)==null)//如果不存在这个班级的话 那么我们就要新建一个班级
        {
            //则新创班级
            currentClass = new Class(classNum);
            addClass(currentClass);
            //加入学生
            //判断课程检查方式
            currentStudent = new Student(studentNum, studentName);
            currentClass.addStudent(currentStudent);//放入指定班级里面去
            students.add(currentStudent);//把当前学生加入到学生信息表中 方便之后的输出
            solveGrade(a);//处理成绩的问题
        }
        else//如果这个班存在的话 不用再判断有无学生
        {
            currentClass = searchClass(classNum);//找到班级 如果没有这个班的话 就再上面创建这个班级
            if(currentClass.searchStudent(studentNum) == null)
            {
                currentStudent = new Student(studentNum,studentName);
                currentClass.addStudent(currentStudent);
                if(students.contains(currentStudent)){}
                else{
                    students.add(currentStudent);
                }
            }
            else
            {
                currentStudent = currentClass.searchStudent(studentNum);
                if(students.contains(currentStudent)){}
                else{
                    students.add(currentStudent);
                }
            }
            solveGrade(a);
        }
    }
    Class searchClass(String classNum)
    {
        for (Class aClass : classes) {
            if (aClass.num.equals(classNum))
                return aClass;
        }
        return  null;
    }
    void addClass(Class currentClass)
    {
        classes.add(currentClass);
    }
    void solveGrade(String a)
    {//记得用return 退出当前的方法
        String [] b = a.split(" ");
        //单独对实验课进行判断
        if(b.length >5) {
            if (coursemenu.searchCourse(b[2]) != null)//学生选的这门课是存在的
            {
                currentCourse = coursemenu.searchCourse(b[2]);
                if (currentCourse.type.equals("实验")) {
                    if (currentStudent.courses.contains(currentCourse)) {
                    } else {
                        //说明这个是实验的考试所以长度是大于5的
                        //20201103 张三 java 3 70 80 90 100 这个是错误的输入
                        //实验次数至少4次,不超过9次
                        int testTime = Integer.parseInt(b[3]);//这个是实验的次数的
                        if (testTime + 4 == b.length)//说明格式是正确的
                        {
                            if((b.length-4)>=4&&(b.length-4)<=9) {
                                int totalNum = 0;
                                for (int i = 0; i < testTime; i++) {
                                    totalNum += Integer.parseInt(b[4 + i]);
                                }
                                totalNum /= testTime;
                                currentStudent.addCourse(currentCourse);
                                currentStudent.setMark(totalNum);
                                currentClass.setMark(totalNum);
                                currentCourse.setMark(totalNum);
                            }
                            else{
                                currentStudent.hasChooseError = true;
                                //currentClass.studentmenu.remove(currentStudent);
                                //currentClass.studentNum--;
                                System.out.println("wrong format");
                            }
                        } else {
                            currentStudent.hasChooseError = true;
                            //currentClass.studentmenu.remove(currentStudent);
                            // currentClass.studentNum--;
                            System.out.println("wrong format");
                        }
                    }
                } else {
                    System.out.println(b[0] + " " + b[1] + " : access mode mismatch");//模式不匹配
                }
            } else//在课表上面不存在该课
            {
                System.out.println(b[2] + " does not exist");//课不存在
            }
            return ;
        }
        if(b.length==5)//说明考查方式是考试的形式
        {
            int normalScore = Integer.parseInt(b[3]);//平时分
            int examScore = Integer.parseInt(b[4]);//考试分
            if(coursemenu.searchCourse(b[2])!=null)//学生选的这门课是存在的
            {
                currentCourse = coursemenu.searchCourse(b[2]);
                if(currentCourse.type.equals("考试"))//长度为5 所以是和考试有关的
                {
                    if(currentStudent.courses.contains(currentCourse)){}
                    else {
                        currentStudent.addCourse(currentCourse);
                        currentStudent.setMark(normalScore, examScore);
                        currentClass.setMark(normalScore, examScore);
                        currentCourse.setMark(normalScore, examScore);
                    }
                }
                else
                {
                    System.out.println(b[0] + " " + b[1] + " : access mode mismatch");//模式不匹配
                }
            }
            else//在课表上面不存在该课
            {
                System.out.println(b[2] + " does not exist");//课不存在
            }
        }
        else //存在而且该考察方式是考察
        {
            int normalScore = Integer.parseInt(b[3]);//平时分
            if(coursemenu.searchCourse(b[2])!=null)//学生选的这门课是存在的
            {
                currentCourse = coursemenu.searchCourse(b[2]);
                if(currentCourse.type.equals("考察"))//长度为5 所以是和考试有关的
                {
                    if(currentStudent.courses.contains(currentCourse)){}
                    else {
                        currentStudent.addCourse(currentCourse);
                        currentStudent.setMark(normalScore);
                        currentClass.setMark(normalScore);
                        currentCourse.setMark(normalScore);
                    }
                }
                else
                {
                    System.out.println(b[0] + " " + b[1] + " : access mode mismatch");//模式不匹配
                }
            }
            else//在课表上面不存在该课
            {
                System.out.println(b[2] + " does not exist");//课不存在
            }
        }
    }
    void showStudent()
    {
        Collections.sort(students);
        for(Student s : students)
        {
            s.stuShow();
        }
    }
    void showClass()
    {
        Collections.sort(classes);
        for(Class s : classes)
        {
            s.classShow();
        }
    }
    void showCourse()
    {
        Collections.sort(coursemenu.classmenu);
        for(Course s : coursemenu.classmenu)
        {
            s.courseShow();
        }
    }
}

  

 

我的类图如下:

 

 

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

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

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

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

//动物发生模拟器. 请在下面的【】处添加代码。
public class AnimalShoutTest2 {
public static void main(String[] args) {
Cat cat = new Cat();
Dog dog = new Dog();
Goat goat = new Goat();
speak(cat);
speak(dog);
speak(goat);
}
//定义静态方法speak()
【】

}

//定义抽象类Animal
【】class Animal{
【】
}
//基于Animal类,定义猫类Cat,并重写两个抽象方法
class Cat 【】{
【】
【】
}
//基于Animal类,定义狗类Dog,并重写两个抽象方法
class Dog 【】{
【】
【】
}
//基于Animal类,定义山羊类Goat,并重写两个抽象方法
class Goat 【】{
【】
【】
}
输入样例:

输出样例:
猫的叫声:喵喵
狗的叫声:汪汪
山羊的叫声:咩咩
代码长度限制
16 KB
时间限制
400 ms
内存限制
64 MB

代码:

public class Main {
    public static void main(String[] args) {
        Cat cat = new Cat();
        Dog dog = new Dog();
        Goat goat = new Goat();
        speak(cat);
        speak(dog);
        speak(goat);
    }
    //定义静态方法speak()
    public static void speak(Animal animal)
    {
        if(animal instanceof Cat)
        {
            animal.shout();
        }
        else if (animal instanceof Dog)
        {
            animal.shout();
        }
        else{
            animal.shout();
        }
    }
}
//定义抽象类Animal
abstract  class Animal{
    abstract Animal getAnimalClass();
    abstract void shout();
}
//基于Animal类,定义猫类Cat,并重写两个抽象方法
class Cat extends Animal{

    @Override
    Animal getAnimalClass() {
        return null;
    }

    @Override
    void shout() {
        System.out.println("猫的叫声:喵喵");
    }
}
//基于Animal类,定义狗类Dog,并重写两个抽象方法
class Dog extends Animal{

    @Override
    Animal getAnimalClass() {
        return null;
    }

    @Override
    void shout() {
        System.out.println("狗的叫声:汪汪");
    }
}
//基于Animal类,定义山羊类Goat,并重写两个抽象方法
class Goat extends Animal {

    @Override
    Animal getAnimalClass() {
        return null;
    }

    @Override
    void shout() {
        System.out.println("山羊的叫声:咩咩");
    }
}

  

第八次作业:

7-1 容器-ArrayList-排序

 

题目描述

编辑

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

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

姓名可能会存在重复。

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

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

以“end”为输入结束标志

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

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

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

20201124 张少军 83 75
20201136 李四 78 86
20201118 郑觉先 80 62
end
输出样例:
在这里给出相应的输出。例如:

20201136 李四 164
20201124 张少军 158
20201118 郑觉先 142

代码:

import java.util.*;

public class Main {
    public static void main(String[] args) {
        Scanner reader = new Scanner(System.in);
        List<Student> students = new ArrayList<>();
        while (reader.hasNextLine()) {
            String line = reader.nextLine().trim();
            if ("end".equals(line)) {
                break;
            } else {
                String[] infos = line.split("\\s+");
                Student student = new Student(infos[0], infos[1], Integer.parseInt(infos[2]), Integer.parseInt(infos[3]));
                students.add(student);
            }
        }

        Collections.sort(students, (a, b) -> {
            int abSum = a.math + a.physic;
            int bbSum = b.math + b.physic;
            if (abSum != bbSum) {
                return bbSum - abSum;
            } else {
                return students.indexOf(a) - students.indexOf(b);
            }
        });

        for (Student student : students) {
            System.out.println(String.format("%s %s %d", student.num, student.name, student.math + student.physic));
        }
    }

    static class Student {
        String num;
        String name;
        int math;
        int physic;

        public Student(String num, String name, int math, int physic) {
            this.num = num;
            this.name = name;
            this.math = math;
            this.physic = physic;
        }
    }
}

  

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

课程成绩统计程序-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.util.*;
import java.text.*;
class Calculate_grades {
    int stu_all_grades(Data_storage data_storage,String num){//单个学生总课程平均分计算  返回一个分数 1)
        int count =0;//这个学生有几门课
        int sum = 0;
        for (Map.Entry<String, Score> entry : data_storage.stu__st_cour.get(num).gradeMap.entrySet()) {
            Score value = entry.getValue();
            if(Integer.parseInt(value.total_scores)>=0) {
                count++;
                sum += Integer.parseInt(value.total_scores);
            }
        }
        if(count!=0)
            return sum/count;
        else
            return -100;//没有参加任何考试
    }
    int[] single_course_grades(Data_storage data_storage,String name){ //2) 课程名
        int count = 0;
        int[] aver_grade = new int[3];//0:平时成绩 1:期末考试 2:总分平均
        for (Map.Entry<String, StudentsAll_mes> e : data_storage.stu__st_cour.entrySet()) {//遍历选课类:num-选课类
            StudentsAll_mes value = e.getValue();
            for (Map.Entry<String, Score> entry : value.gradeMap.entrySet()) {//遍历选课类:course.name-Score
                String key1 = entry.getKey();
                Score value1 = entry.getValue();
                if (key1.equals(name)) {
                    if(Integer.parseInt(value1.total_scores)>=0) {//总分为- 说明算成绩无效
                        count++;
                        aver_grade[2] += Integer.parseInt(value1.total_scores);
                        if (value1 instanceof Test_Score) {
                            if (Integer.parseInt(value1.total_scores) >= 0) {
                                aver_grade[0] += Integer.parseInt(((Test_Score) value1).normal_score);
                                aver_grade[1] += Integer.parseInt(((Test_Score) value1).end_score);
                            }
                        } else if (value1 instanceof Inspect_Score){
                            if (Integer.parseInt(value1.total_scores) >= 0) {
                                aver_grade[0] = -100;//不需要平时成绩
                                aver_grade[1] += Integer.parseInt(((Inspect_Score) value1).end_score);
                            }
                        }else if(value1 instanceof Lab_Score){
                            if(Integer.parseInt(value1.total_scores)>=0){
                                aver_grade[0] = -100;
                                aver_grade[1] += aver_grade[1] += Integer.parseInt(value1.total_scores);
                            }
                        }
                    }
                }
            }
        }
        if(count!=0) {
            for (int i = 0; i < 3; i++) {
                aver_grade[i] = aver_grade[i] / count;
            }
        }else {
            for (int i = 0; i < 3; i++) {
                aver_grade[i] = -100;
            }
        }
        return aver_grade;
    }
    int Class_grades(Data_storage data_storage,String num){//3)
        int sum = 0;
        int count = 0;
        for (Map.Entry<String, Student> mapEntry : data_storage.classes.get(num).students.entrySet()) {//班级号-Student类
            Student value = mapEntry.getValue();//遍历这个班级的所有学生
            for (Map.Entry<String, StudentsAll_mes> e : data_storage.stu__st_cour.entrySet()) {//stu_num-选课类
                String key1 = e.getKey();//遍历学生的选课类 学号
                StudentsAll_mes value1 = e.getValue();
                if (key1.equals(value.num)) {//选课类中 跟输入的学号一样
                    for (Map.Entry<String, Score> entry : value1.gradeMap.entrySet()) {//该num所有成绩遍历
                        Score gra = entry.getValue();
                        if(Integer.parseInt(gra.total_scores)>=0) {//有效才算
                            sum += Integer.parseInt(gra.total_scores);
                            count++;
                        }
                    }
                }
            }
        }
        if(count!=0)
            return sum/count;
        else
            return -100;
    }
    void final_score(Data_storage data_storage,String num){//计算没门课的成绩 学号
        data_storage.stu__st_cour.get(num).gradeMap.forEach((key,value)->{//学号  成绩
            if(value instanceof Test_Score&&((Test_Score) value).normal_score.matches("\\d+")&&((Test_Score) value).end_score.matches("\\d+")) {
                double tem = ((Test_Course) data_storage.courses.get(key)).normal_weight*Integer.parseInt(((Test_Score) value).normal_score);
                double tem1 = ((Test_Course) data_storage.courses.get(key)).end_weight*Integer.parseInt(((Test_Score) value).end_score);
                value.total_scores = String.valueOf((int)(tem+tem1));
            }else if(value instanceof Inspect_Score&&((Inspect_Score) value).end_score.matches("\\d+")){
                value.total_scores = ((Inspect_Score) value).end_score;
            }else if(value instanceof Lab_Score&&((Lab_Score) value).lab_num.matches("\\d+")){
                float sum = 0;
                int i=0;
                for (Integer score : ((Lab_Score) value).scores) {
                    sum+= score* ((Lab_Course) data_storage.courses.get(key)).weights.get(i);
                    i++;
                }
                value.total_scores = String.valueOf((int)sum);
            }
        });
    }
}
class Class {
    String num;
    TreeMap<String, Student> students = new TreeMap<>(); //班级里的学生 学号 学生
    Class(String num){
        this.num = num;
    }
}
class Course {
    String type;
    String test_way;
    String name;
    Course(String name,String type, String test_way){
        this.type = type;
        this.name = name;
        this.test_way = test_way;
    }
}
class Inspect_Course extends Course{
    Inspect_Course(String name, String type, String test_way) {
        super(name, type, test_way);
    }
}
class Test_Course extends Course{
    double normal_weight;
    double end_weight;

    Test_Course(String name, String type, String test_way,String normal_weight,String end_weight) {
        super(name, type, test_way);
        this.normal_weight = Float.parseFloat(normal_weight);
        this.end_weight = Float.parseFloat(end_weight);
    }
}
class Lab_Course extends Course{
    int sub_scores_num;
    ArrayList<Float> weights = new ArrayList<>();
    Lab_Course(String name, String type, String test_way,String line) {
        super(name, type, test_way);
        String[] lines = line.split(" ");
        sub_scores_num = Integer.parseInt(lines[3]);
        for(int i=4;i<lines.length; i++){
            weights.add(Float.parseFloat(lines[i]));
        }
    }
}
class Data_storage {
    TreeMap<String , Course> courses;//课程  k:课程名 v:课程
    TreeMap<String, Class> classes = new TreeMap<>();//班级 k:班级号V:班级
    TreeMap<String, StudentsAll_mes> stu__st_cour;//选课类学生类结合 k:学号 v:选课类
    InAndOut_put output = new InAndOut_put();
    Data_storage(){
        //学生和选课类结合
        stu__st_cour = new TreeMap<>(Data_storage::compare);//重写排序
        courses = new TreeMap<>(Data_storage::compare);
    }

    private static int compare(String o1, String o2) {

        try {
            Comparator<Object> comparator = Collator.getInstance(Locale.CHINA);
            if (comparator.compare(o1, o2) < 0) {
                return -1;
            } else if (comparator.compare(o1, o2) > 0) {
                return 1;
            }
        } catch (Exception ignored) {
        }
        return 0;
    }

    void setInspectCourses(String name, String type, String test_way){
        if(!courses.containsKey(name)) {
            courses.put(name, new Inspect_Course(name, type, test_way));
        }
    }
    void setTestCourses(String name, String type, String test_way,String normal_weight, String end_weight){
        if(!courses.containsKey(name)) {
            courses.put(name, new Test_Course(name, type, test_way,normal_weight, end_weight));
        }
    }
    void setLabCourses(String name, String type, String test_way,String line){
        if(!courses.containsKey(name)) {
            courses.put(name, new Lab_Course(name, type, test_way,line));
        }
    }
    void setClasses(String num){
        if(!classes.containsKey(num)) {
            classes.put(num, new Class(num));
        }
    }
    void setStudents(String clas_num, String name, String num){//班级号 姓名 学号
        if(classes.containsKey(clas_num)){
            if(!classes.get(clas_num).students.containsKey(num))
                classes.get(clas_num).students.put(num,new Student(name,num));
        }
    }
    void setStu__st_courAndMap(String num,String course,String normal_score,String end_score){//添加选课类  学生姓名 课程名称 分数
        if(!stu__st_cour.containsKey(num)){
            stu__st_cour.put(num,new StudentsAll_mes(num,course,normal_score,end_score));
        }
        else{
            stu__st_cour.get(num).setGradeMap(course,normal_score,end_score);
        }
    }
    void setStu__st_courAndMap(String num,String course,String end_score){
        if(!stu__st_cour.containsKey(num)){
            stu__st_cour.put(num,new StudentsAll_mes(num,course,end_score));
        }
        else{
            stu__st_cour.get(num).setGradeMap(course,end_score);
        }
    }
    void set_lab_grades(String stu_num,String course,String lab_num,String grades){
        ArrayList<Integer> scores = new ArrayList<>();
        String[] tem = grades.split(" ");
        for(int i=3;i<tem.length;i++){
            if(tem[i].matches("\\d+"))
                scores.add(Integer.parseInt(tem[i]));
        }
        if(!stu__st_cour.containsKey(stu_num)){
            StudentsAll_mes tem_stu_mes = new StudentsAll_mes();
            tem_stu_mes.set_lab_stu_mes(stu_num,course,lab_num,scores);
            stu__st_cour.put(stu_num,tem_stu_mes);
        }else{
            stu__st_cour.get(stu_num).set_lab_gradeMap(course,lab_num,scores);
        }
    }
}
class Input_Format {
    String regex_c_test = "^[\\u4e00-\\u9fa5a-zA-Z0-9]{1,10}\\s(必修|选修)\\s考试\\s((0.\\d{1,2})|(1-9?))\\s((0.\\d{1,2})|(1-9?))$";
    String regex_c_inspect = "[\\u4e00-\\u9fa5a-zA-Z0-9]{1,10}\\s选修\\s考察$";
    String regex_c_lab = "^[\\u4e00-\\u9fa5a-zA-Z0-9 ]{1,10}\\s实验\\s实验\\s[4-9]\\s((0.\\d{1,2})|(1-9?))(\\s((0.\\d{1,2})|(1-9?))){3,9}$";
    String regex_CS = "^\\d{8}\\s+[\\u4e00-\\u9fa5a-zA-Z0-9]{1,10}\\s+[\\u4E00-\\u9FA5A-Za-z0-9]{1,10}\\s*((100)|(\\d{1,2})|(0))?\\s+((100)|(\\d{1,2})|(0))$";
    String regex_lab = "^\\d{8}\\s[\\u4e00-\\u9fa5a-zA-Z0-9]{1,10}\\s[\\u4e00-\\u9fa5a-zA-Z0-9 ]{1,10}\\s((100)|([1-9]\\d)|\\d)(\\s((100)|([1-9]\\d)|\\d)){2,9}$";
    boolean isEnd = true;//结束标志
    String[] strings;
    void inputProcessing(String line,Data_storage data_storage) {
        lineProcessing(line);//分割
        data_storage.output.add_input(line);//存储
        if(line.matches(regex_c_inspect)){
            data_storage.setInspectCourses(strings[0],strings[1],strings[2]);
        }else if(line.matches(regex_c_lab)){
            data_storage.setLabCourses(strings[0],strings[1],strings[2],line);
        }else if(line.matches(regex_c_test)){
            data_storage.setTestCourses(strings[0],strings[1],strings[2],strings[3],strings[4]);//成绩信息
        } else if(line.matches(regex_CS)||line.matches(regex_lab)){
            data_storage.setClasses(strings[0].substring(0,6));
            data_storage.setStudents(strings[0].substring(0, 6), strings[1], strings[0]);//学生的添加
            if (data_storage.courses.containsKey(strings[2])) {//课程里有这个课
                if (data_storage.courses.get(strings[2]).type.equals("选修")) {//
                    if (data_storage.courses.get(strings[2]).test_way.equals("考试")&&strings.length == 5) {
                        data_storage.setStu__st_courAndMap(strings[0], strings[2], strings[3], strings[4]);
                    }else if(data_storage.courses.get(strings[2]).test_way.equals("考察")&&strings.length==4){
                        data_storage.setStu__st_courAndMap(strings[0], strings[2], strings[3]);
                    } else {
                        data_storage.setStu__st_courAndMap(strings[0], strings[2], "no access", "no access");
                    }
                } else if (data_storage.courses.get(strings[2]).type.equals("必修")) {//
                    if (strings.length == 5) {
                        data_storage.setStu__st_courAndMap(strings[0], strings[2], strings[3],strings[4]);
                    } else {//无效
                        data_storage.setStu__st_courAndMap(strings[0], strings[2], "no access", "no access");
                    }
                } else if(data_storage.courses.get(strings[2]).type.equals("实验")){
                    if(strings.length == 3+((Lab_Course) data_storage.courses.get(strings[2])).sub_scores_num){
                        data_storage.set_lab_grades(strings[0],strings[2], String.valueOf(((Lab_Course) data_storage.courses.get(strings[2])).sub_scores_num),line);
                    }else{
                        data_storage.set_lab_grades(strings[0],strings[2],"num error","no access");
                    }
                }
            }else{
                data_storage.setStu__st_courAndMap(strings[0], strings[2], "not exist");
            }
        }
    }
    void lineProcessing(String line){
        strings = line.split(" ");
    }
}
class Inspect_Score extends Score{
    String end_score;
    Inspect_Score(String end_score) {
        this.end_score = end_score;
    }
}
class  Output_Format {
    Calculate_grades calculate = new Calculate_grades();
    String regex_c_test = "^[\\u4e00-\\u9fa5a-zA-Z0-9]{1,10}\\s(必修|选修|实验)\\s(考试|考察|实验)\\s((\\d{1,2})|(1-9?))\\s((\\d{1,2})|(1-9?))$";
    String regex_c_test_e = "^[\\u4e00-\\u9fa5a-zA-Z0-9]{1,10}\\s(必修|选修|实验)\\s(考试|考察|实验)\\s((0.\\d{1,2})|(1-9?))\\s((0.\\d{1,2})|(1-9?))$";
    String regex_c_inspect = "[\\u4e00-\\u9fa5a-zA-Z0-9]{1,10}\\s(必修|选修|实验)\\s(考试|考察|实验)$";
    String regex_c_lab = "^[\\u4e00-\\u9fa5a-zA-Z0-9]{1,10}\\s(必修|选修|实验)\\s(考试|考察|实验)\\s[4-9]\\s((0.\\d{1,2})|(1-9?))(\\s((0.\\d{1,2})|(1-9?))){1,10}$";
    String regex_CS = "^\\d{8}\\s+[\\u4e00-\\u9fa5a-zA-Z0-9]{1,10}\\s+[\\u4e00-\\u9fa5a-zA-Z0-9]{1,10}\\s*((100)|(\\d{1,2})|(0))?\\s+((100)|(\\d{1,2})|(0))$";
    String regex_lab = "^\\d{8}\\s[\\u4e00-\\u9fa5a-zA-Z0-9]{1,10}\\s[\\u4e00-\\u9fa5a-zA-Z0-9]{1,10}\\s((100)|([1-9]\\d)|\\d)(\\s((100)|([1-9]\\d)|\\d)){1,20}$";
    void outputProcessing(Data_storage data) {
        data.classes.forEach((num,Class)-> Class.students.forEach((name, student)-> calculate.final_score(data,student.num)));
        for(String i:data.output.input){
            String[] tem = i.split(" ");
            if(i.matches(regex_c_test_e)||i.matches(regex_c_test)||i.matches(regex_c_inspect)||i.matches(regex_c_lab)){
                if(tem[1].equals("必修")&&(tem[2].equals("考察")||tem[2].equals("实验"))){
                    data.output.add_output(tem[0] + " : course type & access mode mismatch");
                }else if(tem[1].equals("实验")&&!tem[2].equals("实验")) {
                    data.output.add_output(tem[0] + " : course type & access mode mismatch");
                }else if(tem[1].equals("选修")&&tem[2].equals("实验")) {
                    data.output.add_output(tem[0] + " : course type & access mode mismatch");
                }
                if(tem[1].equals("实验")&&tem[2].equals("实验")) {
                    if(tem.length-4>=4&&tem.length - 4<=9) {
                        if (Integer.parseInt(tem[3]) != tem.length - 4) {
                            data.output.add_output(tem[0] + " : number of scores does not match");
                            data.courses.remove(tem[0]);
                            continue;
                        }
                        float tem_weight = 0;
                        for (int j = 4; j < tem.length; j++) {
                            tem_weight += Float.parseFloat(tem[j]);
                        }
                        if (Math.abs(tem_weight - 1) > 0.0001) {
                            data.output.add_output(tem[0] + " : weight value error");
                            data.courses.remove(tem[0]);
                            continue;
                        }
                    }else{
                        try {
                            if (Integer.parseInt(tem[3]) != tem.length - 4) {
                                data.output.add_output(tem[0] + " : number of scores does not match");
                                data.courses.remove(tem[0]);
                                continue;
                            }
                        } catch (Exception ignored) {

                        }
                    }
                }if((tem[1].equals("必修")||tem[1].equals("选修"))&&tem[2].equals("考试")){
                    if(tem.length-3==2) {
                        float tem_weight = Float.parseFloat(tem[3]) + Float.parseFloat(tem[4]);
                        if (Math.abs(tem_weight - 1) > 0.0001) {
                            data.output.add_output(tem[0] + " : weight value error");
                            data.courses.remove(tem[0]);
                        }
                    }
                }
            }else if(i.matches(regex_CS)||i.matches(regex_lab)) {
                if(!data.courses.containsKey(tem[2])){//不存在
                    data.output.add_output(tem[2]+" does not exist");
                    data.stu__st_cour.get(tem[0]).gradeMap.remove(tem[2]);
                }else{
                    if(data.courses.get(tem[2]).type.equals("必修") && tem.length!=5) {//必修 但是只有期末成绩
                        data.output.add_output(tem[0]+" "+tem[1]+" : access mode mismatch");
                    }else if(data.courses.get(tem[2]).type.equals("选修")) {
                        if ((data.courses.get(tem[2]).test_way.equals("考试") && tem.length != 5) ||
                                (data.courses.get(tem[2]).test_way.equals("考察") && tem.length != 4))
                            data.output.add_output(tem[0] + " " + tem[1] + " : access mode mismatch");
                    }else if(data.courses.get(tem[2]).type.equals("实验")){
                        if(data.courses.get(tem[2]).test_way.equals("实验")&&(tem.length-3<4||tem.length-3>9||tem.length-3!=((Lab_Course) data.courses.get(tem[2])).sub_scores_num))
                            data.output.add_output(tem[0] + " " + tem[1] + " : access mode mismatch");
                    }
                }
            }else if(!i.equals("end")){
                data.output.add_output("wrong format");
            }
        }
        data.classes.forEach((cla_num,Class1)->{//遍历所有班级
            Class1.students.forEach((stu_num,student)->{
                int tem=calculate.stu_all_grades(data,stu_num);
                if(tem>=0)
                    data.output.add_output(stu_num+" "+Class1.students.get(stu_num).name+" "+tem);
                else
                    data.output.add_output(stu_num+" "+Class1.students.get(stu_num).name+" "+"did not take any exams");
            });
        });
        data.courses.forEach((key,value)-> {
            int[] tem = calculate.single_course_grades(data, key);
            if (tem[0] < 0 && tem[1] < 0 && tem[2] < 0) {//三个为- 则没成绩
                data.output.add_output(key + " has no grades yet");
            }else {
                if (value.type.equals("选修") || value.type.equals("必修") || value.type.equals("实验")) {
                    data.output.add_output(key + " " + tem[2]);
                }
            }
        });
        data.classes.forEach((num,Class)->{
            int tem = calculate.Class_grades(data,num);
            if(tem>=0) {
                data.output.add_output(num + " " + tem);
            }else
                data.output.add_output(num+" has no grades yet");
        });
    }
    void output_all(Data_storage data){
        data.output.output.forEach(System.out::println);
    }
}
abstract class Score {
    String total_scores = "-100";
}
class Student {
    String name;
    String num;
    Student(String name, String num) {
        this.name = name;
        this.num = num;
    }
}
class StudentsAll_mes {
    String num;//学生
    TreeMap<String,Score> gradeMap =new TreeMap<>();
    StudentsAll_mes(String stu_name, String course, String normal_score,String test_score){
        this.num = stu_name;
        gradeMap.put(course,new Test_Score(normal_score,test_score));
    }
    StudentsAll_mes(String stu_name, String course, String test_score){
        this.num = stu_name;
        gradeMap.put(course,new Inspect_Score(test_score));
    }

    public StudentsAll_mes() {

    }
    void set_lab_stu_mes(String stu_num,String course,String lab_num,ArrayList<Integer> scores){
        this.num = stu_num;
        gradeMap.put(course,new Lab_Score(lab_num,scores));
    }
    void set_lab_gradeMap(String course,String lab_num,ArrayList<Integer> scores){
        if(!gradeMap.containsKey(course))
            gradeMap.put(course,new Lab_Score(lab_num,scores));
    }
    void setGradeMap(String course, String normal_score,String test_score){
        if(!gradeMap.containsKey(course))
            gradeMap.put(course, new Test_Score(normal_score,test_score));
    }
    void setGradeMap(String course,String test_score){
        if(!gradeMap.containsKey(course))
            gradeMap.put(course,new Inspect_Score(test_score));
    }

}
class Test_Score extends Score{
    String normal_score;
    String end_score;
    Test_Score(String normal_score,String end_score) {
        this.normal_score = normal_score;
        this.end_score = end_score;
    }
}
class Lab_Score extends Score {
    String lab_num;//试验次数

    ArrayList<Integer> scores;
    Lab_Score(String lab_num,ArrayList<Integer> scores){
        this.lab_num = lab_num;
        this.scores = scores;
    }
}
class InAndOut_put {
    List<String> output = new ArrayList<>();
    List<String> input = new ArrayList<>();
    void add_output(String out){
        output.add(out);
    }
    void add_input(String out){
        input.add(out);
    }
}
public class Main {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        Input_Format inputFormat = new Input_Format();//输入
        Output_Format outputFormat = new Output_Format();//输出
        Data_storage data_storage = new Data_storage();
        while (inputFormat.isEnd){
            String inputLine = scanner.nextLine();
            if(inputLine.equals("end")){
                inputFormat.isEnd = false;
                break;
            }
            inputFormat.inputProcessing(inputLine,data_storage);
        }
        outputFormat.outputProcessing(data_storage);
        outputFormat.output_all(data_storage);
    }
}

  

 

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

输入n,然后连续输入n个身份证号。
然后根据输入的是sort1还是sort2,执行不同的功能。输入的不是sort1或sort2,则输出exit并退出。
输入sort1,将每个身份证的年月日抽取出来,按年-月-日格式组装,然后对组装后的年-月-日升序输出。
输入sort2,将所有身份证按照里面的年月日升序输出。
注意:处理输入的时候,全部使用Scanner的nextLine()方法,以免出错。

输入样例:
6
410425198309308225
320203197206115011
431227196108033146
330226196605054190
34080019810819327X
320111197112301539
sort1
sort2
e

输出样例:
1961-08-03
1966-05-05
1971-12-30
1972-06-11
1981-08-19
1983-09-30
431227196108033146
330226196605054190
320111197112301539
320203197206115011
34080019810819327X
410425198309308225
exit;

代码:

import java.util.*;
 
public class Main {
 
	public static void main(String[] args) {
		Scanner scan = new Scanner(System.in);
		int n = scan.nextInt();
		scan.nextLine();
		String A[] = new String[n], C[] = new String[n];
		for (int i = 0; i < n; i++) {
			A[i] = scan.nextLine();
		}
 
		String B = scan.nextLine();
 
		for (; B.equals("sort1") || B.equals("sort2");) {
			if (B.equals("sort1")) {
				for (int j = 0; j < n; j++) {
					C[j] = A[j].substring(6, 10) + "-" + A[j].substring(10, 12) + "-" + A[j].substring(12, 14);
				}
				Arrays.sort(C);
				for (int j = 0; j < n; j++) {
					System.out.println(C[j].toString());
				}
			} else if (B.equals("sort2")) {
				for (int j = 0; j < n; j++) {
					C[j] = A[j].substring(6, 14);
				}
				Arrays.sort(C);
				for (int j = 0; j < n; j++)
					for (int k = 0; k < n; k++)
						if (A[k].contains(C[j]))
							System.out.println(A[k].toString());
			}
			System.out.println("exit");
			B = scan.nextLine();
		}
 
		scan.close();
	}
 
}

  

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

全屏浏览题目

切换布局
作者 郑如滨
单位 集美大学
定义IntegerStack接口,用于声明一个存放Integer元素的栈的常见方法:

public Integer push(Integer item);
//如果item为null,则不入栈直接返回null。如果栈满,也返回null。如果插入成功,返回item。

public Integer pop(); //出栈,如果为空,则返回null。出栈时只移动栈顶指针,相应位置不置为null
public Integer peek(); //获得栈顶元素,如果为空,则返回null.
public boolean empty(); //如果为空返回true
public int size(); //返回栈中元素个数
定义IntegerStack的实现类ArrayIntegerStack,内部使用数组实现。创建时,可指定内部数组大小。

main方法说明
输入n,建立可包含n个元素的ArrayIntegerStack对象
输入m个值,均入栈。每次入栈均打印入栈返回结果。
输出栈顶元素,输出是否为空,输出size
使用Arrays.toString()输出内部数组中的值。
输入x,然后出栈x次,每次出栈均打印。
输出栈顶元素,输出是否为空,输出size
使用Arrays.toString()输出内部数组中的值。
思考
如果IntegerStack接口的实现类内部使用ArrayList来存储元素,怎么实现?测试代码需要进行什么修改?

输入样例
5
3
1 2 3
2

输出样例
1
2
3
3,false,3
[1, 2, 3, null, null]
3
2
1,false,1
[1, 2, 3, null, null]

代码:

import java.util.Arrays;
import java.util.Scanner;

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

class ArrayIntegerStack implements IntegerStack{
    private Integer[] arr;
    private int top = 0;

    public ArrayIntegerStack(int n){
        arr = new Integer[n];
        Arrays.fill(arr, null);
    }

    public ArrayIntegerStack(){}

    @Override
    public String toString() {
        return Arrays.toString(arr);
    }

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

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

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

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

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

public class Main {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        int n = scanner.nextInt();
        ArrayIntegerStack ais = new ArrayIntegerStack(n);
        int m = scanner.nextInt();
        while(m-- > 0){
            int item = scanner.nextInt();
            System.out.println(ais.push(item));
        }
        System.out.println(ais.peek() + "," + ais.empty() + "," + ais.size());
        System.out.println(ais);
        int x = scanner.nextInt();
        while(x-- > 0){
            System.out.println(ais.pop());
        }
        System.out.println(ais.peek() + "," + ais.empty() + "," + ais.size());
        System.out.println(ais);
    }
}

  

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

全屏浏览题目

切换布局
作者 郑如滨
单位 集美大学
Java每个对象都继承自Object,都有equals、toString等方法。
现在需要定义PersonOverride类并覆盖其toString与equals方法。

1. 新建PersonOverride类
a. 属性:String name、int age、boolean gender,所有的变量必须为私有(private)。

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

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

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

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

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

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

输入样例:
1
3
zhang 10 true
zhang 10 true
zhang 10 false

输出样例:
default-1-true
zhang-10-true
zhang-10-false
2
[public PersonOverride(), public PersonOverride(java.lang.String,int,boolean)]

代码:

import java.util.Arrays;
import java.util.Objects;
import java.util.Scanner;

class PersonOverride{
    private String name;
    private int age;
    private boolean gender;

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

    @Override
    public boolean equals(Object obj){
        if (this == obj){
            return true;
        }
        if(obj == null)
        {
            return false;
        }
        if (this.getClass() != obj.getClass()){
            return false;
        }
        PersonOverride p = (PersonOverride)obj;
        boolean b1 = Objects.equals((this.name), p.name);
        boolean b2 = (this.age == p.age);
        boolean b3 = (this.gender == p.gender);
        if(b1 && b2 && b3){
            return true;
        }
        return false;
    }

    public PersonOverride(String _name, int _age, boolean _gender){
        name = _name;
        age = _age;
        gender = _gender;
    }
    public PersonOverride(){
        this("default",1,true);
    }
}

public class Main {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        int n1 = scanner.nextInt();
        PersonOverride[] persons1 = new PersonOverride[n1];
        for (int i = 0; i < n1; i++) {
            persons1[i] = new PersonOverride();
        }
        int n2 = scanner.nextInt();
        scanner.nextLine();
        PersonOverride[] persons2 = new PersonOverride[n2];
        for (int i = 0; i < n2; i++) {
            String str = scanner.nextLine();
            String[] arr = str.split("\\s+");
            PersonOverride temp = new PersonOverride(arr[0],Integer.parseInt(arr[1]),Boolean.valueOf(arr[2]));
            boolean flag = true;
            for (int j = 0; j < n2; j++) {
                if(temp.equals(persons2[j])){
                    flag = false;
                }
            }
            if(flag){
                persons2[i] = new PersonOverride(arr[0],Integer.parseInt(arr[1]),Boolean.valueOf(arr[2]));
            }
        }
        for (int i = 0; i < n1; i++) {
            System.out.println(persons1[i]);
        }
        int i,count = 0;
        for (i = 0; i < n2; i++) {
            if(persons2[i] == null){
                continue;
            }
            count++;
            System.out.println(persons2[i]);
        }
        System.out.println(count);
        System.out.println(Arrays.toString(PersonOverride.class.getConstructors()));
    }
}

  

期末考试:

    

7-1 立体图形问题
分数 10

全屏浏览题目

切换布局
作者 段喜龙
单位 南昌航空大学
编程求得正方体和正三棱锥的表面积和体积,要求必须体现扩展性(继承)和多态性。

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


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

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.*;
public optionArea(double side) {
super(side);
this.height = ((side * Math.sqrt(6)) / 3);
}


public double getUse() {
return (((((Math.sqrt(3) / 2) * concept)*concept) / 2)*height)/3;
}


public double getassist() {
double Area = (((Math.sqrt(3) / 2) * concept)*concept) / 2;
return Area*4;
}
}

public class Main {
public static void main(String[] args) {
Scanner obtain = new Scanner(System.in);
double bianchang = obtain.nextDouble();
display(new Fix(bianchang));
display(new optionArea(bianchang));
}

public static void display(Editor solid) {
double value = solid.getassist();
System.out.println(String.format("%.2f",value));
value = solid.getUse();
System.out.println(String.format("%.2f",value));
}
}
class ObtainArea{
double semidiameter;
public void inSemidiameter(double semidiameter) {
if(semidiameter>0) {
this.semidiameter=semidiameter;
}else {
System.out.println("Wrong Format");
}
}
public double obtainSpace() {
double shuzhi;
shuzhi=Math.PI*semidiameter*semidiameter;
return shuzhi;
}
}

  

7-2 魔方问题
分数 20

全屏浏览题目

切换布局
作者 段喜龙
单位 南昌航空大学
问题描述:本问题中的魔方有两种,一种是正方体魔方,一种是正三棱锥魔方,其中,正方体或正三棱锥魔方是由单元正方体或正三棱锥组成,单元正方体或正三棱锥的个数由阶数(即层数)决定,即魔方边长=阶数*单元边长。魔方如下图所示:

 


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

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

 

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


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.*;
public double obtainsurarea() {
double sideLength = with * side; // 魔方边长
double baseArea = ((Math.sqrt(3) / 4) * sideLength * sideLength)*4; // 底面积
return baseArea; // 表面积公式
}
public double obtainv() {
double provide = with * side;
double height = Math.sqrt(6) / 3 * provide; // 高
return ((Math.sqrt(3) / 4) * provide * provide) * height / 3; // 体积公式
}
}

public class Main {

public static void main(String[] args) {
Scanner obtain = new Scanner(System.in);
String code = obtain.next(); // 输入正方体魔方颜色
int ppyht = obtain.nextInt(); // 输入正方体魔方阶数
double side = obtain.nextDouble(); // 输入正方体魔方单元边长

Mofanglei identy = new Fixarea(code, ppyht, side); // 创建正方体魔方对象

code = obtain.next();
ppyht = obtain.nextInt();
side = obtain.nextDouble();

Mofanglei ident8 = new Fixrugarlur(code, ppyht, side); // 创建正三棱锥魔方对象
display(identy); // 显示正方体魔方信息
display(ident8); // 显示正三棱锥魔方信息
}
public static void display(Mofanglei cube) {
cube.imessment();
}
}

abstract class Soild {
protected double sideLength;

public Soild(double sideLength) {
this.sideLength = sideLength;
}

public abstract double getSurfaceArea();

public abstract double getVolume();
}
class Cube {
public Cube(double sideLength) {
}
}

  

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

代码:

import java.util.*;
}
public double obtainv() {
double provide = layer * statement;
double height = Math.sqrt(6) / 3 * provide; // 高
return ((Math.sqrt(3) / 4) * provide * provide) * height / 3; // 体积公式
}
}
public class Main {
public static void main(String[] args) {
Scanner obtain = new Scanner(System.in);
List<Mofanglei> mofangleiList = new ArrayList<>();
while (true) {
int useing = obtain.nextInt();
if (useing == 0) {
break;
}
String code = obtain.next();
int fixesy = obtain.nextInt();
double orande = obtain.nextDouble();
if (useing == 1) {
mofangleiList.add(new Fixarea(code, fixesy, orande));
} else if (useing == 2) {
mofangleiList.add(new Fixrugarlur(code, fixesy, orande));
}
}
Collections.sort(mofangleiList, Comparator.comparingDouble(Mofanglei::getVolume));
for (Mofanglei cube : mofangleiList) {
cube.imessment();
}
}
}
abstract class Soild {
protected double httyimage;

public Soild(double obtainassist) {
this.httyimage = obtainassist;
}

public abstract double obtainsurface();

public abstract double getVolume();
}
class Cube {
public Cube(double sideLength) {
}
}

  

 

三.踩坑心得

编写代码时,要注意可读性和可维护性,使用合适的命名、注释和代码结构。可以考虑封装一些功能成函数,提高代码的可维护性。

数据结构的选择:在解决这个问题时,需要选择合适的数据结构来存储和处理数据。例如,选择使用列表来存储课程成绩和学生信息,使用映射来存储班级和课程成绩的关系。

数组越界问题:在处理输入时,需要注意数组越界的问题。例如,当解析学生信息时,需要确保课程索引在合法范围内,否则可能导致数组越界异常。

算法的设计和实现:在计算平均成绩时,需要设计合适的算法来处理课程成绩和权重。例如,我使用两个循环来遍历课程成绩和分项成绩,并计算总成绩。

 

四.改进与建议

确保你所使用的算法和数据结构是高效的,并且能够满足程序的需求。在适当的情况下,可以考虑使用更高效的数据结构或算法,以提高程序的性能。

Java程序在内存管理方面拥有一定的优势,但仍然需要注意内存使用情况。确保及时释放不再使用的对象,避免内存泄漏问题。可以使用一些内存分析工具来监测和解决内存问题。

对于需要处理大量并发请求或需要执行长时间任务的程序,可以考虑使用多线程或并发处理来提高程序的性能和响应能力。使用Java提供的线程池和并发工具可以简化并发编程的复杂性。

合理处理异常对于程序的稳定性和可靠性很重要。使用try-catch语句来捕获和处理异常,并根据具体情况选择适当的异常处理策略,如重试、回滚或记录错误信息。

考虑将学生、课程和成绩等信息封装成对象,以提高代码的可读性和可维护性。可以创建Student、Course、Grade等类来表示相关的实体,并在类中定义适当的方法和属性来处理相关操作。

考虑使用更合适的数据结构来存储和处理数据。例如,可以使用Set来存储班级信息,使用Map来存储学生和成绩的关系。这样可以更方便地进行数据的查找和操作。

使用流式操作和Lambda表达式:使用Java 8引入的流式操作和Lambda表达式可以简化代码,并提高代码的可读性。例如,可以使用stream()方法和filter()方法来过滤数据,使用map()方法来转换数据等。

在处理输入时,需要考虑错误处理和异常处理。例如,当解析学生信息时,可以使用try-catch块来捕获可能的异常,如数组越界异常等,并进行相应的处理。

在设计和实现功能时,遵循单一职责原则,确保每个类和方法只负责一项具体的功能。这样可以提高代码的可维护性和复用性。

 

 

五.总结

   

      我学习了面向对象编程(OOP)的概念和Java中的实现。Java是一门面向对象的编程语言,理解面向对象的思想和原则对于编写高质量的Java程序至关重要。我学习了类、对象、继承、封装、多态等概念,并通过实践项目来巩固所学知识。接着,我学习了Java的核心 API。Java提供了丰富的类库和API,掌握常用的API对于开发各类应用程序非常重要。我学习了字符串处理、集合框架、IO操作、多线程编程等常用的API,并通过实例来加深理解和熟悉使用。此外,我也了解并学习了一些常用的开发工具和框架。例如,我使用过Eclipse和IntelliJ IDEA等集成开发环境来编写和调试Java程序,学习了使用Maven进行项目构建和依赖管理,熟悉了Spring框架的基本用法等。这些工具和框架能够提高开发效率和代码质量。在学习Java的过程中,我也遇到了一些挑战。有时候遇到难以理解的概念或者错误的代码逻辑,但我通过查阅文档、阅读相关书籍、参考网上的教程和提问论坛等途径,最终都能够解决问题和理清思路。、