oop 第三次作业总结

发布时间 2023-06-27 13:43:14作者: &0钊

目录

 · 前言

 · 设计与分析

 · 踩坑心得

 · 改进建议

 · 总结

(1)前言:总结之前所涉及到的知识点、题量、难度等情况

 

(2)设计与分析:重点对题目的提交源码进行分析,可参考SourceMonitor的生成报表内容以及PowerDesigner的相应类图,要有相应的解释和心得(做到有图有真相),主要分析PTA中成绩计算系列的题目(可适当扩展题目分析,例如关键字数量计算等复杂题目)

7-1 课程成绩统计程序-1
分数 100
作者 蔡轲
单位 南昌航空大学

某高校课程从性质上分为:必修课、选修课,从考核方式上分为:考试、考察。

考试的总成绩由平时成绩、期末成绩分别乘以权重值得出,比如平时成绩权重0.3,期末成绩权重0.7,总成绩=平时成绩*0.3+期末成绩*0.7。

考察的总成绩直接等于期末成绩

必修课的考核方式必须为考试,选修课可以选择考试、考察任一考核方式。

1、输入:

包括课程、课程成绩两类信息。

课程信息包括:课程名称、课程性质、考核方式(可选,如果性质是必修课,考核方式可以没有)三个数据项。

课程信息格式:课程名称+英文空格+课程性质+英文空格+考核方式

课程性质输入项:必修、选修

考核方式输入选项:考试、考察

课程成绩信息包括:学号、姓名、课程名称、平时成绩(可选)、期末成绩

课程信息格式:学号+英文空格+姓名+英文空格+课程名称+英文空格+平时成绩+英文空格+期末成绩

以上信息的相关约束:

1)平时成绩和期末成绩的权重默认为0.3、0.7

2)成绩是整数,不包含小数部分,成绩的取值范围是【0,100】

3)学号由8位数字组成

4)姓名不超过10个字符

5)课程名称不超过10个字符

6)不特别输入班级信息,班级号是学号的前6位。

2、输出:

输出包含三个部分,包括学生所有课程总成绩的平均分、单门课程成绩平均分、单门课程总成绩平均分、班级所有课程总成绩平均分。

为避免误差,平均分的计算方法为累加所有符合条件的单个成绩,最后除以总数。

1)学生课程总成绩平均分按学号由低到高排序输出

格式:学号+英文空格+姓名+英文空格+总成绩平均分

如果某个学生没有任何成绩信息,输出:学号+英文空格+姓名+英文空格+"did not take any exams"

2)单门课程成绩平均分分为三个分值:平时成绩平均分(可选)、期末考试平均分、总成绩平均分,按课程名称的字符顺序输出

格式:课程名称+英文空格+平时成绩平均分+英文空格+期末考试平均分+英文空格+总成绩平均分

如果某门课程没有任何成绩信息,输出:课程名称+英文空格+"has no grades yet"

3)班级所有课程总成绩平均分按班级由低到高排序输出

格式:班级号+英文空格+总成绩平均分

如果某个班级没有任何成绩信息,输出:班级名称+英文空格+ "has no grades yet"

异常情况:

1)如果解析某个成绩信息时,课程名称不在已输入的课程列表中,输出:学号+英文空格+姓名+英文空格+":"+课程名称+英文空格+"does not exist"

2)如果解析某个成绩信息时,输入的成绩数量和课程的考核方式不匹配,输出:学号+英文空格+姓名+英文空格+": access mode mismatch"

以上两种情况如果同时出现,按第一种情况输出结果。

3)如果解析某个课程信息时,输入的课程性质和课程的考核方式不匹配,输出:课程名称+" : course type & access mode mismatch"

4)格式错误以及其他信息异常如成绩超出范围等,均按格式错误处理,输出"wrong format"

5)若出现重复的课程/成绩信息,只保留第一个课程信息,忽略后面输入的。

信息约束:

1)成绩平均分只取整数部分,小数部分丢弃

参考类图:


image.png

输入样例1:

仅有课程。例如:

java 必修 考试
数据结构 选修 考试
形式与政治 选修 考察
end
 

输出样例1:

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

java has no grades yet
数据结构 has no grades yet
形式与政治 has no grades yet
 

输入样例2:

单门考试课程 单个学生。例如:

java 必修 考试
20201103 张三 java 20 40
end
 

输出样例2:

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

20201103 张三 34
java 20 40 34
202011 34
 

输入样例3:

单门考察课程 单个学生。例如:

java 选修 考察
20201103 张三 java 40
end
 

输出样例3:

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

20201103 张三 40
java 40 40
202011 40
 

输入样例4:

考试课程 单个学生 不匹配的考核方式。例如:

java 必修 考试
20201103 张三 java 20
end
 

输出样例4:

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

20201103 张三 : access mode mismatch
20201103 张三 did not take any exams
java has no grades yet
202011 has no grades yet
 

输入样例5:

单门课程,单个学生,课程类型与考核类型不匹配。例如:

java 必修 考察
20201103 张三 java 40
end
 

输出样例5:

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

java : course type & access mode mismatch
java does not exist
20201103 张三 did not take any exams
202011 has no grades yet
 

输入样例6:

单门课程,多个学生。例如:

java 选修 考察
20201103 李四 java 60
20201104 王五 java 60
20201101 张三 java 40
end
 

输出样例6:

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

20201101 张三 40
20201103 李四 60
20201104 王五 60
java 53 53
202011 53
 

输入样例7:

单门课程,单个学生,课程类型与考核类型不匹配。例如:

形式与政治 必修 考试
数据库 选修 考试
java 选修 考察
数据结构 选修 考察
20201103 李四 数据结构 70
20201103 李四 形式与政治 80 90
20201103 李四 java 60
20201103 李四 数据库 70 78
end
 

输出样例7:

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

20201103 李四 73
java 60 60
数据结构 70 70
数据库 70 78 75
形式与政治 80 90 87
202011 73
 

输入样例8:

单门课程,单个学生,成绩越界。例如:

数据结构 选修 考察
20201103 李四 数据结构 101
end
 

输出样例8:

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

wrong format
数据结构 has no grades yet
 

输入样例9:

多门课程,多个学生,多个成绩。例如:

形式与政治 必修 考试
数据库 选修 考试
java 选修 考察
数据结构 选修 考察
20201205 李四 数据结构 70
20201103 李四 形式与政治 80 90
20201102 王五 java 60
20201211 张三 数据库 70 78
end
 

输出样例9:

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

20201102 王五 60
20201103 李四 87
20201205 李四 70
20201211 张三 75
java 60 60
数据结构 70 70
数据库 70 78 75
形式与政治 80 90 87
202011 73
202012 72
 
代码长度限制
16 KB
时间限制
1000 ms
内存限制
64 MB
import java.util.Scanner;
public class Main
{
    public static void main(String[] args) {
        Scanner input = new Scanner(System.in);
        Course course = new Course();
        Student student = new Student();
        AbstractScore examination = new Examination();
        AbstractScore investigation = new Investigation();
        int flag = 0;
        String nextLine = input.nextLine();
        while (!nextLine.equals("end")) {
            String[] lineArray = nextLine.split(" ");
            if (lineArray.length > 3) {
                student.setId(Integer.parseInt(lineArray[0]));
                student.setName(lineArray[1]);
                if (lineArray.length == 4) {
                    flag = 1;
                    examination.setScore(Integer.parseInt(lineArray[3]));
                }
                if (lineArray.length == 5) {
                    flag = 2;
                    investigation.setInveScore(Integer.parseInt(lineArray[3]));
                    examination.setExamScore(Integer.parseInt(lineArray[4]));
                    examination.setScore(examination.getAverScore(Integer.parseInt(lineArray[3]), Integer.parseInt(lineArray[4])));

                }

            }

            if (lineArray.length == 3) {
                course.setCourseName(lineArray[0]);
                course.setCourseType(lineArray[1]);
            }
            nextLine = input.nextLine();
        }
        if (flag != 0) {
            System.out.println(student.getId() + " " + student.getName() + " " + examination.getScore());
            if (flag == 1) {
                System.out.println(course.getCourseName() + " " + examination.getScore() + " " + examination.getScore());
            }
            if (flag == 2) {
                System.out.println(course.getCourseName() + " " + investigation.getInveScore() + " " + examination.getExamScore() + " " + examination.getScore());
            }
            System.out.println(student.getClassNum() + " " + examination.getScore());
        }

    }
}

class Student {
    private String name;
    private int Id;
    private int ClassNum;
    public Student(){

    }

    public void setName(String name) {
        this.name = name;
    }

    public void setId(int id) {
        Id = id;
    }

    public void setClassNum(int classNum) {
        ClassNum = classNum;
    }

    public int getId() {
        return Id;
    }

    public String getName() {
        return name;
    }


    public int getClassNum() {
        ClassNum = Id/100;

        return ClassNum;
    }
}
class Examination extends AbstractScore {
    public Examination(){

    }
}
class Investigation extends AbstractScore {
    public Investigation() {

    }
}
class Course {
    private String CourseName;
    public String CourseType;
    public Course(){

    }

    public String getCourseName() {
        return CourseName;
    }

    public String getCourseType() {
        return CourseType;
    }

    public void setCourseName(String courseName) {
        CourseName = courseName;
    }

    public void setCourseType(String courseType) {
        CourseType = courseType;
    }
}
class AbstractScore {
    private int averScore;
    private int score;
    private int inveScore;
    private int examScore;
    public AbstractScore(){

    }


    public int getScore() {
        return score;
    }

    public int getAverScore(int inveScore,int examScore) {
        averScore = (int)(0.3 * inveScore + 0.7 * examScore);
        return averScore;
    }

    public void setScore(int score) {
        this.score = score;
    }
    public void setInveScore(int inveScore) {
        this.inveScore = inveScore;
    }
    public void setExamScore(int examScore) {
        this.examScore = examScore;
    }
    public int getInveScore() {
        return inveScore;
    }
    public int getExamScore() {
        return examScore;
    }


}

 

 SourceMonitor 报表

Metrics Details For File 'Main.java'
--------------------------------------------------------------------------------------------

Parameter Value
========= =====
Project Directory C:\Users\limbol\IdeaProjects\sy3\src\oop\
Project Name
Checkpoint Name Baseline
File Name Main.java
Lines 156
Statements 90
Percent Branch Statements 8.9
Method Call Statements 28
Percent Lines with Comments 0.0
Classes and Interfaces 6
Methods per Class 3.83
Average Statements per Method 2.17
Line Number of Most Complex Method 5
Name of Most Complex Method Main.main()
Maximum Complexity 9
Line Number of Deepest Block 19
Maximum Block Depth 5
Average Block Depth 1.93
Average Complexity 1.35

--------------------------------------------------------------------------------------------
Most Complex Methods in 6 Class(es): Complexity, Statements, Max Depth, Calls

AbstractScore.AbstractScore() 1, 0, 0, 0
AbstractScore.getAverScore() 1, 2, 2, 0
AbstractScore.getExamScore() 1, 1, 2, 0
AbstractScore.getInveScore() 1, 1, 2, 0
AbstractScore.getScore() 1, 1, 2, 0
AbstractScore.setExamScore() 1, 1, 2, 0
AbstractScore.setInveScore() 1, 1, 2, 0
AbstractScore.setScore() 1, 1, 2, 0
Course.Course() 1, 0, 0, 0
Course.getCourseName() 1, 1, 2, 0
Course.getCourseType() 1, 1, 2, 0
Course.setCourseName() 1, 1, 2, 0
Course.setCourseType() 1, 1, 2, 0
Examination.Examination() 1, 0, 0, 0
Investigation.Investigation() 1, 0, 0, 0
Main.main() 9, 31, 5, 28
Student.getClassNum() 1, 2, 2, 0
Student.getId() 1, 1, 2, 0
Student.getName() 1, 1, 2, 0
Student.setClassNum() 1, 1, 2, 0
Student.setId() 1, 1, 2, 0
Student.setName() 1, 1, 2, 0
Student.Student() 1, 0, 0, 0

--------------------------------------------------------------------------------------------
Block Depth Statements

0 8
1 32
2 28
3 8
4 8
5 6
6 0
7 0
8 0
9+ 0
--------------------------------------------------------------------------------------------

 

 

7-1 统计Java程序中关键词的出现次数
分数 100
作者 段喜龙
单位 南昌航空大学

编写程序统计一个输入的Java源码中关键字(区分大小写)出现的次数。说明如下:

  • Java中共有53个关键字(自行百度)
  • 从键盘输入一段源码,统计这段源码中出现的关键字的数量
  • 注释中出现的关键字不用统计
  • 字符串中出现的关键字不用统计
  • 统计出的关键字及数量按照关键字升序进行排序输出
  • 未输入源码则认为输入非法

输入格式:

输入Java源码字符串,可以一行或多行,以exit行作为结束标志

输出格式:

  • 当未输入源码时,程序输出Wrong Format
  • 当没有统计数据时,输出为空
  • 当有统计数据时,关键字按照升序排列,每行输出一个关键字及数量,格式为数量\t关键字

输入样例:

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

//Test public method
public HashMap(int initialCapacity) {
        this(initialCapacity, DEFAULT_LOAD_FACTOR);
    }
    public HashMap(int initialCapacity, float loadFactor) {
        if (initialCapacity < 0)
            throw new IllegalArgumentException("Illegal initial capacity: " +
                                               initialCapacity);
        if (initialCapacity > MAXIMUM_CAPACITY)
            initialCapacity = MAXIMUM_CAPACITY;
        if (loadFactor <= 0 || Float.isNaN(loadFactor))
            throw new IllegalArgumentException("Illegal load factor: " +
                                               loadFactor);
        this.loadFactor = loadFactor;
        this.threshold = tableSizeFor(initialCapacity);
    }
exit
 

输出样例:

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

1	float
3	if
2	int
2	new
2	public
3	this
2	throw
 
代码长度限制
16 KB
时间限制
400 ms
内存限制
64 MB
 
import java.util.*;

public class Main {
    public static void main(String[] args) {
        Scanner input = new Scanner(System.in);
        StringBuffer text = new StringBuffer();

        String text1 = input.nextLine();
        int s = 0;
        while (!text1.equals("exit")) {
            s++;
            text = text.append(text1.replaceAll("//.*"," ").replaceAll("\".*\""," ").replaceAll("/\\*\\s*.*\\s*\\*/", " "));
            text1 = input.nextLine();
        }

        if(s == 0){
            System.out.println("Wrong Format");
            
        }
        countKeyword(String.valueOf(text));
    }

    public static void countKeyword(String text) {

        String[] keywords = {"abstract", "assert", "boolean", "break", "byte", "case", "catch", "char",
                "class", "const", "continue", "default", "do", "double", "else", "enum", "extends","false", "final", "finally",
                "float", "for", "goto", "if", "implements", "import", "instanceof", "int", "interface", "long", "native", "new", "null",
                "package", "private", "protected", "public", "return", "short", "static", "strictfp", "super", "switch", "synchronized", "this",
                "throw", "throws", "transient", "true","try", "void", "volatile", "while"};
        TreeMap<String, Integer> map = new TreeMap<>();

        for (String keyword : keywords) {
            int count = 0;
            int index = text.indexOf(keyword);
            while (index != -1) {
                count++;
                index = text.indexOf( keyword, index + keyword.length());
            }
            if (count > 0) {
                map.put(keyword, count);
            }
        }
        ArrayList<Map.Entry<String, Integer>> list = new ArrayList<>(map.entrySet());

        for (Map.Entry<String, Integer> entry:list){

            System.out.println(entry.getValue() + "\t" + entry.getKey());

        }
    }
}

 

 

Metrics Details For File 'Main.java'
--------------------------------------------------------------------------------------------

Parameter Value
========= =====
Project Directory C:\Users\limbol\IdeaProjects\sy3\src\oop\
Project Name
Checkpoint Name Baseline
File Name Main.java
Lines 54
Statements 29
Percent Branch Statements 20.7
Method Call Statements 15
Percent Lines with Comments 0.0
Classes and Interfaces 1
Methods per Class 2.00
Average Statements per Method 12.00
Line Number of Most Complex Method 25
Name of Most Complex Method Main.countKeyword()
Maximum Complexity 5
Line Number of Deepest Block 38
Maximum Block Depth 4
Average Block Depth 2.24
Average Complexity 4.00

--------------------------------------------------------------------------------------------
Most Complex Methods in 1 Class(es): Complexity, Statements, Max Depth, Calls

Main.countKeyword() 5, 13, 4, 7
Main.main() 3, 11, 3, 8

--------------------------------------------------------------------------------------------
Block Depth Statements

0 3
1 2
2 12
3 9
4 3
5 0
6 0
7 0
8 0
9+ 0
--------------------------------------------------------------------------------------------

 

 

 

(3)采坑心得:对源码的提交过程中出现的问题及心得进行总结,务必做到详实,拿数据、源码及测试结果说话,切忌假大空

第1题:

 第2题:

 

(4)改进建议:对相应题目的编码改进给出自己的见解,做到可持续改进

(5)总结:对本阶段(10-16周)综合性总结,学到了什么,哪些地方需要进一步学习及研究,对教师、课程、作业、实验、课上及课下组织方式等方面的改进建议及意见。

 

 

 

2.对本门课程的教学理念(OBE)、教学方法(边讲边练)、教学组织(线上线下混合式教学)、教学过程(PTA题目集驱动)及教学模式(BOPPPS)进行客观性评价,给出相应建议及意见,希望大家畅所欲言,重点查摆问题,多否定,少肯定