第三次Blog作业

发布时间 2023-06-27 17:59:50作者: 顾念乔安

1.前言

   这几次的题目集题目难度一般,但是成绩统计的题目比较难,写的不太好。题目也比较少,但可能是学的不太好,所以做的不太行。都到了最后的阶段了,学的还这么差,感觉好烦,不知道该怎么办。

2.设计与分析

  第九次作业集

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

 代码如下:

import java.util.*;

public class Main {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        StringBuilder sb = new StringBuilder();
        String line;
        while (!(line = scanner.nextLine()).equals("exit")) {
            sb.append(line).append('\n');
        }
        String sourceCode = sb.toString();
        if (sourceCode.trim().isEmpty()) {
            System.out.println("Wrong Format");
            return;
        }
        Set<String> keywords = new HashSet<>(Arrays.asList(
                "abstract", "assert", "boolean", "break", "byte", "case", "catch", "char", "class",
                "const", "continue", "default", "do", "double", "else", "enum", "extends", "final",
                "finally", "float", "for", "if", "goto", "implements", "import", "instanceof", "int",
                "interface", "long", "native", "new", "package", "private", "protected", "public",
                "return", "short", "static", "strictfp", "super", "switch", "synchronized", "this",
                "throw", "throws", "transient", "try", "void", "volatile", "while"
        ));
        Map<String, Integer> keywordCount = new TreeMap<>();
        int i = 0;
        while (i < sourceCode.length()) {
            char c = sourceCode.charAt(i);
            if (c == '/') {
                if (i + 1 < sourceCode.length() && sourceCode.charAt(i + 1) == '/') {
                    i = sourceCode.indexOf('\n', i + 2);
                    if (i == -1) {
                        break;
                    }
                } else if (i + 1 < sourceCode.length() && sourceCode.charAt(i + 1) == '*') {
                    i = sourceCode.indexOf("*/", i + 2);
                    if (i == -1) {
                        break;
                    }
                    i += 2;
                } else {
                    i++;
                }
            } else if (c == '\"') {
                i++;
                while (i < sourceCode.length() && sourceCode.charAt(i) != '\"') {
                    if (sourceCode.charAt(i) == '\\') {
                        i++;
                    }
                    i++;
                }
                i++;
            } else if (c == '\'') {
                i++;
                while (i < sourceCode.length() && sourceCode.charAt(i) != '\'') {
                    if (sourceCode.charAt(i) == '\\') {
                        i++;
                    }
                    i++;
                }
                i++;
            } else if (Character.isLetter(c) || c == '_') {
                int j = i + 1;
                while (j < sourceCode.length() && (Character.isLetterOrDigit(sourceCode.charAt(j)) || sourceCode.charAt(j) == '_')) {
                    j++;
                }
                String word = sourceCode.substring(i, j);
                if (keywords.contains(word)) {
                    keywordCount.put(word, keywordCount.getOrDefault(word, 0) + 1);
                }
                i = j;
            } else {
                i++;
            }
        }
        if (keywordCount.isEmpty()) {
            System.out.println();
        } else {
            for (Map.Entry<String, Integer> entry : keywordCount.entrySet()) {
                System.out.printf("%d\t%s\n", entry.getValue(), entry.getKey());
            }
        }
    }
}

  分析如下:查找关键字,并记录关键字的个数,可以利用map,进行键值对方式存储,存储关键字,而且题目需要按照关键字升序排列,所以可以用TreeMap。读取字符串,把不需要的部分去掉,并且要注意删去或改变一些字符时,如new_Bag,删除_,而不是把_改成空格,最后再按空格分隔提取单词。

  第十次题目集

    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 existd

代码如下:

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

public class Main {
    public static void main(String[] args) {
        Scanner input = new Scanner(System.in);
        String s = null;
        HashMap<String, Student> Sites = new HashMap<String, Student>();
        while (!"end".equals(s)){

            s = input.nextLine();
            if (!"end".equals(s)){
                String [] sr = s.split(" ");
                Student student = new Student(sr[1],Integer.parseInt(sr[2]));
                Sites.put(sr[0],student);
            }
            else
                break;
        }
        int m = 0;
        String sc = input.nextLine();
        for(Map.Entry<String,Student> i: Sites.entrySet()){
            if (sc.equals(i.getKey())){
                System.out.println(i.getKey() +" "+ i.getValue().getName() +" " +i.getValue().getScores());
            m=1;
            }
        }
        if (m==0){
            System.out.println("The student "+ sc + " does not exist");
        }
    }
}
class Student{
    private String name;
    private int scores;

    public Student(String name, int scores) {
        this.name = name;
        this.scores = scores;
    }

    public String getName() {
        return name;
    }

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

    public int getScores() {
        return scores;
    }

    public void setScores(int scores) {
        this.scores = scores;
    }
}

  分析如下:将学生的信息存入HashMap里,将学号作为索引,再搜索学生信息并输出。

7-2 容器-HashMap-排序
分数 10
作者 蔡轲
单位 南昌航空大学

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

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

姓名可能会存在重复。

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

输入格式:

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

以“end”为输入结束标志

输出格式:

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

输入样例:

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

20201124 张少军 83
20201136 李四 78
20201118 郑觉先 80
end
 

输出样例:

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

20201136 李四 78
20201124 张少军 83
20201118 郑觉先 80

 代码如下:

import java.util.*;

public class Main {
    public static void main(String[] args) {
        Scanner input = new Scanner(System.in);
        String s = null;
        TreeMap<String, Student> sites = new TreeMap<>(new Comparator<String>() {
            @Override
            public int compare(String o1, String o2) {
                return o2.compareTo(o1);
            }
        });
        while (!"end".equals(s)) {
            s = input.nextLine();
            if (!"end".equals(s)) {
                String[] sr = s.split(" ");
                Student student = new Student(sr[1], Integer.parseInt(sr[2]));
                sites.put(sr[0], student);
            } else
                break;
        }
        for (Map.Entry<String, Student> entry : sites.entrySet()) {
            System.out.println(entry.getKey() + " " + entry.getValue().getName() + " " + entry.getValue().getScores());
        }
    }
}

class Student {
    private String name;
    private int scores;

    public Student(String name, int scores) {
        this.name = name;
        this.scores = scores;
    }

    public String getName() {
        return name;
    }

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

    public int getScores() {
        return scores;
    }

    public void setScores(int scores) {
        this.scores = scores;
    }
}

  分析如下:跟上题差不多,比较两个学生的学号大小,再将学生的信息排序,之后输出就行了。

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

课程成绩统计程序-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)成绩平均分只取整数部分,小数部分丢弃

参考类图(与第一次相同,其余内容自行补充):


e724fa4193aa9ee32e78a68cd96fd6df_22401e04-c501-4b28-bb65-dabe39d374e7.png

 

输入样例1:

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

java 实验 实验
20201103 张三 java 4 70 80 90
end
 

输出样例1:

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

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

输入样例2:

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

java 实验 实验
20201103 张三 java 3 70 80 90
end
 

输出样例2:

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

wrong format
java has no grades yet
 

输入样例3:

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

java 必修 实验
20201103 张三 java 3 70 80 90 100
end
 

输出样例3:

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

java : course type & access mode mismatch
wrong format
 

输入样例4:

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

java 必修 实验
20201103 张三 java 4 70 80 90 105
end
 

输出样例4:

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

java : course type & access mode mismatch
wrong format
 

 

输入样例5:

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

java 选修 考察
C语言 选修 考察
java实验 实验 实验
编译原理 必修 考试
20201101 王五 C语言 76
20201216 李四 C语言 78
20201307 张少军 编译原理 82 84
20201103 张三 java实验 4 70 80 90 100
20201118 郑觉先 java 80
20201328 刘和宇 java 77
20201220 朱重九 java实验 4 60 60 80 80
20201132 王萍 C语言 40
20201302 李梦涵 C语言 68
20201325 崔瑾 编译原理 80 84
20201213 黄红 java 82
20201209 赵仙芝 java 76
end
 

输出样例5:

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

20201101 王五 76
20201103 张三 85
20201118 郑觉先 80
20201132 王萍 40
20201209 赵仙芝 76
20201213 黄红 82
20201216 李四 78
20201220 朱重九 70
20201302 李梦涵 68
20201307 张少军 83
20201325 崔瑾 82
20201328 刘和宇 77
C语言 65 65
java 78 78
java实验 77
编译原理 81 84 82
202011 70
202012 76
202013 77

  代码如下:

import java.util.Scanner;
public class Main {
    private static int totalGrades;
    private static Student student = new Student();
    private static Course course = new Course();
    private static ExamGrades examGrades = new ExamGrades();
    private static ExamineGrades examineGrades = new ExamineGrades();
    private static ExperimentGrades experimentGrades = new ExperimentGrades();
    private static Klass klass = new Klass();
    private static String closing;
    private static String a;
    public static void main(String[] args) {
        Scanner input = new Scanner(System.in);
        course.setCourse(input.next());
        course.setCompulsory(input.next());
        course.setAssessmentMethod(input.next());
        if((course.getCompulsory().equals("必修")||course.getCompulsory().equals("选修"))
                && course.getAssessmentMethod().equals("考试")) {
            student.setsClassNumber(input.next());
            if (student.getsClassNumber().length() == 8) {
                klass.setClassNumber(student.getsClassNumber().substring(0, 6));
                student.setName(input.next());
                course.setCourse(input.next());
                examGrades.setUsualGrades(Integer.parseInt(input.next()));
                a = input.next();
                if(a.equals("end")){
                    System.out.println(student.getsClassNumber() + " " + student.getName() + " : access mode mismatch");
                    System.out.println(student.getsClassNumber() + " " + student.getName() + " did not take any exams");
                    System.out.println(course.getCourse() + " has no grades yet");
                    System.out.println(klass.getClassNumber() + " has no grades yet");
                }
                else {
                    examGrades.setFinalGrades(Integer.parseInt(a));
                    closing = input.next();
                    totalGrades = (int) (examGrades.getFinalGrades() * 0.7 + examGrades.getUsualGrades() * 0.3);
                    System.out.println(student.getsClassNumber() + " " + student.getName() + " " + totalGrades);
                    System.out.println(course.getCourse() + " " + examGrades.getUsualGrades() + " "
                            + examGrades.getFinalGrades() + " " + totalGrades);
                    System.out.println(klass.getClassNumber() + " " + totalGrades);
                }
            }
        }
        else if(course.getCompulsory().equals("选修") && course.getAssessmentMethod().equals("考察")){
            student.setsClassNumber(input.next());
            klass.setClassNumber(student.getsClassNumber().substring(0, 6));
            student.setName(input.next());
            course.setCourse(input.next());
            examineGrades.setFinalGrades(Integer.parseInt(input.next()));
            if (examineGrades.getFinalGrades() < 0 || examineGrades.getFinalGrades() > 100){
                System.out.println("wrong format");
                System.out.println(course.getCourse()+" has no grades yet");
            }
            else {
                totalGrades = examineGrades.getFinalGrades();
                closing = input.next();
                System.out.println(student.getsClassNumber() + " " + student.getName() + " " + totalGrades);
                System.out.println(course.getCourse() + " " + examineGrades.getFinalGrades() + " " + totalGrades);
                System.out.println(klass.getClassNumber() + " " + totalGrades);
            }
        }
        else if(course.getCompulsory().equals("必修") && course.getAssessmentMethod().equals("考察")){
            student.setsClassNumber(input.next());
            if (student.getsClassNumber().length() == 8) {
                klass.setClassNumber(student.getsClassNumber().substring(0, 6));
                student.setName(input.next());
                course.setCourse(input.next());
                examGrades.setFinalGrades(Integer.parseInt(input.next()));

            }
            totalGrades = examGrades.getFinalGrades();
            closing = input.next();
            System.out.println(course.getCourse() + " : course type & access mode mismatch");
            System.out.println(course.getCourse() + " does not exist");
            System.out.println(student.getsClassNumber() + " " + student.getName() + " did not take any exams");
            System.out.println(klass.getClassNumber() + " has no grades yet");
        }
        else if (course.getCompulsory().equals("实验")&&course.getAssessmentMethod().equals("实验")){
            String b = input.nextLine();
            while(b.equals("end")){
                String []sc=b.split(" ");
                student.setsClassNumber(sc[0]);
                klass.setClassNumber(student.getsClassNumber().substring(0,6));
                student.setName(sc[1]);
                course.setCourse(sc[2]);
                experimentGrades.setExperimentTimes(Integer.parseInt(sc[3]));
                if(Integer.parseInt(sc[3])<4||Integer.parseInt(sc[3])>9){
                    for (int i = 4;i< sc.length;i++){
                        experimentGrades.setExexperimentGrades(experimentGrades.getExexperimentGrades()+Integer.parseInt(sc[i]));
                        System.out.println("wrong format");
                        System.out.println(course.getCourse()+" has no grades yet");
                    }
                }
                else {
                    for (int i = 4;i< sc.length;i++){
                        experimentGrades.setExexperimentGrades(experimentGrades.getExexperimentGrades()+Integer.parseInt(sc[i]));
                        System.out.println("wrong format");

                    }
                }
                System.out.println(sc[0]);
            }
        }
        System.out.println("wrong format");
                        System.out.print(course.getCourse()+" has no grades yet");
    }
}
abstract class AbstractGrades {
    private int usualGrades;
    private int finalGrades;
    private int totalGrades;
    protected void getGrades(){

    }

    public AbstractGrades() {
    }

    public AbstractGrades(int finalGrades,int usualGrades,int totalGrades) {
        this.finalGrades = finalGrades;
        this.usualGrades = usualGrades;
        this.totalGrades = totalGrades;
    }

    public int getFinalGrades() {
        return finalGrades;
    }

    public void setFinalGrades(int finalGrades) {
        this.finalGrades = finalGrades;
    }

    public int getTotalGrades() {
        return totalGrades;
    }

    public void setTotalGrades(int totalGrades) {
        this.totalGrades = totalGrades;
    }

    public int getUsualGrades() {
        return usualGrades;
    }

    public void setUsualGrades(int usualGrades) {
        this.usualGrades = usualGrades;
    }
}
class Course {
    private String course;
    private String compulsory;
    private String assessmentMethod;

    public String getCourse() {
        return course;
    }

    public Course() {
    }

    public Course(String course,String compulsory,String assessmentMethod) {
        this.course = course;
        this.compulsory = compulsory;
        this.assessmentMethod = assessmentMethod;
    }



    public void setCourse(String course) {
        this.course = course;
    }

    public String getCompulsory() {
        return compulsory;
    }

    public void setCompulsory(String compulsory) {
        this.compulsory = compulsory;
    }

    public String getAssessmentMethod() {
        return assessmentMethod;
    }

    public void setAssessmentMethod(String assessmentMethod) {
        this.assessmentMethod = assessmentMethod;
    }
}

class ExamGrades extends AbstractGrades{
    private int totalGrades;
    @Override
    public void getGrades(){
        if(getFinalGrades() > 0&&getFinalGrades() < 100&&getUsualGrades() > 0&&getUsualGrades() < 100){
            totalGrades = (int) (getFinalGrades() * 0.7 + getUsualGrades() * 0.3);
        }
        else {
            System.out.println("wrong format");
        }
    }

}
class ExamineGrades extends AbstractGrades{
    private int totalGrades;
    @Override
    protected void getGrades(){
        if(getFinalGrades() > 0&&getFinalGrades() < 100){
            totalGrades =  getFinalGrades();
        }
        else {
            System.out.println("wrong format");
        }
    }
}
class ExperimentGrades extends AbstractGrades{
    private int experimentTimes;
    private int exexperimentGrades;

    public int getExperimentTimes() {
        return experimentTimes;
    }

    public void setExperimentTimes(int experimentTimes) {
        this.experimentTimes = experimentTimes;
    }

    public int getExexperimentGrades() {
        return exexperimentGrades;
    }

    public void setExexperimentGrades(int exexperimentGrades) {
        this.exexperimentGrades = exexperimentGrades;
    }
}
class Klass {
    private String ClassNumber;

    public void classNumber(){

    }

    public Klass() {
    }

    public Klass(String classNumber) {
        ClassNumber = classNumber;
    }

    public String getClassNumber() {
        return ClassNumber;
    }

    public void setClassNumber(String classNumber) {
        ClassNumber = classNumber;
    }
}
class Student {
    static Klass klass = new Klass();
    private String sClassNumber;
    private String name;

    public Student() {
    }

    public Student(String sClassNumber,String name) {
        this.sClassNumber = sClassNumber;
        this.name = name;
    }

    public String getsClassNumber() {
        return sClassNumber;
    }

    public void setsClassNumber(String sClassNumber) {
        this.sClassNumber= sClassNumber;
    }

    public String getName() {
        return name;
    }

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

  分析如下:这道题我写不出来,没办法分析。qwq。

7-4 动物发声模拟器(多态)
分数 20
作者 刘凤良
单位 天津仁爱学院

设计一个动物发生模拟器,用于模拟不同动物的叫声。比如狮吼、虎啸、狗旺旺、猫喵喵……。
定义抽象类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 【】{
    【】
    【】
}
 

输入样例:

 
 

输出样例:

猫的叫声:喵喵
狗的叫声:汪汪
山羊的叫声:咩咩

  代码如下:

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){
        System.out.println(animal.getAnimalClass() + "的叫声:" + animal.shout());
    }
}

//定义抽象类Animal
abstract class Animal{
    public String getAnimalClass(){
        return null;
    }

    public String shout(){
        return null;
    }
}
    //基于Animal类,定义猫类Cat,并重写两个抽象方法

class Cat extends Animal{
    @Override
    public String getAnimalClass(){
        return "猫";
    }
    @Override
    public String shout(){
        return "喵喵";
    }
}
    //基于Animal类,定义狗类Dog,并重写两个抽象方法
    class Dog extends Animal{
        @Override
        public String getAnimalClass(){
            return "狗";
        }
    @Override
    public String shout(){
        return "汪汪";
    }
}
    //基于Animal类,定义山羊类Goat,并重写两个抽象方法
    class Goat extends Animal{
    @Override
    public String getAnimalClass(){
        return "山羊";
    }
    @Override
    public String shout(){
        return "咩咩";
    }
}

  分析如下:这题挺简单的,我感觉没什么好分析的。请见谅。

  第十一次题目集

  

7-1 容器-ArrayList-排序
分数 12
作者 蔡轲
单位 南昌航空大学

题目描述

编辑

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

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

姓名可能会存在重复。

要求:使用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) {
        Student student = new Student();
        Scanner input = new Scanner(System.in);
        String s =null;

        List<Student> Sites = new ArrayList<Student>();
        while (!"end".equals(s)) {
            s = input.nextLine();
            if (!"end".equals(s)){
                String[] sc = s.split(" ");
                student.setID(sc[0]);
                student.setName(sc[2]);
                student.setMgrades(Integer.parseInt(sc[2]));
                student.setPgrades(Integer.parseInt(sc[3]));
                student.setAllGrades(Integer.parseInt(sc[2])+Integer.parseInt(sc[3]));
                Sites.add(new Student(sc[0],sc[1], student.getAllGrades()));

            }
        }
        Collections.sort(Sites, new Comparator<Student>() {


            public int compare(Student o1, Student o2) {
                if(o1.getAllGrades() - o2.getAllGrades()>0) {
                    return -1;
                }else if(o1.getAllGrades() - o2.getAllGrades()<0) {
                    return 1;
                }else {
                    return o1.getName().compareTo(o2.getName());
                }
            }
        });
        for(Student p:Sites) {
            System.out.println(p);

        }
    }
}
class Student{
    private String ID;
    private String name;
    private int Mgrades;
    private int Pgrades;
    private int allGrades;
    public Student(String ID, String name, int allGrades) {
        this.ID = ID;
        this.name = name;
        this.allGrades = allGrades;

    }

    public Student() {
    }

    public String getID() {
        return ID;
    }

    public void setID(String ID) {
        this.ID = ID;
    }

    public String getName() {
        return name;
    }

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

    public int getMgrades() {
        return Mgrades;
    }

    public void setMgrades(int mgrades) {
        Mgrades = mgrades;
    }

    public int getPgrades() {
        return Pgrades;
    }

    public void setPgrades(int pgrades) {
        Pgrades = pgrades;
    }

    public int getAllGrades() {
        return allGrades;
    }

    public void setAllGrades(int allGrades) {
        this.allGrades = allGrades;
    }
    @Override
    public String toString() {
        return ID+" " +name + " " +getAllGrades();
    }

}

  分析如下:将学生的信息存到List里,再比较总成绩,进行排序,之后输出就行了。

7-3 jmu-Java-02基本语法-03-身份证排序
分数 9
作者 郑如滨
单位 集美大学
  1. 输入n,然后连续输入n个身份证号。
  2. 然后根据输入的是sort1还是sort2,执行不同的功能。输入的不是sort1或sort2,则输出exit并退出。
    输入sort1,将每个身份证的年月日抽取出来,按年-月-日格式组装,然后对组装后的年-月-日升序输出。
    输入sort2,将所有身份证按照里面的年月日升序输出。

注意:处理输入的时候,全部使用ScannernextLine()方法,以免出错。

输入样例:

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.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Arrays;
import java.util.Date;
import java.util.Scanner;

public class Main {
    public static void main(String[] args) throws ParseException {
        Scanner input = new Scanner(System.in);
        int n = input.nextInt();
        String sc[] = new String[n+1];
        for(int i = 0;i<n+1;i++){
            sc[i] = input.nextLine();
        }
        String s =null;
        String all[]=new String[n+1];
        String a = null;
        boolean loop = true;
        while(loop) {
            s = input.nextLine();
            switch (s) {
                case "sort1" :
                    for (int i = 1; i < n + 1; i++) {
                        all[i] = sc[i].substring(6, 10) + "-" + sc[i].substring(10, 12) + "-" + sc[i].substring(12, 14);
                    }
                    for (int i = 1; i < n + 1; i++) {
                        for (int j = 1; j < n + 1; j++) {
                            SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
                            Date date1 = sdf.parse(all[i]);
                            Date date2 = sdf.parse(all[j]);
                            if (date1.compareTo(date2) < 0) {
                                a = all[i];
                                all[i] = all[j];
                                all[j] = a;
                            }
                        }
                    }
                    for (int i = 1; i < n + 1; i++) {
                        System.out.println(all[i]);
                    }
                    break;
                case "sort2" :
                    for (int i = 1; i < n + 1; i++) {
                        all[i] = sc[i].substring(6, 10) + "-" + sc[i].substring(10, 12) + "-" + sc[i].substring(12, 14);
                    }
                    for (int i = 1; i < n + 1; i++) {
                        for (int j = 1; j < n + 1; j++) {
                            SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
                            Date date1 = sdf.parse(all[i]);
                            Date date2 = sdf.parse(all[j]);
                            if (date1.compareTo(date2) < 0) {
                                a = all[i];
                                all[i] = all[j];
                                all[j] = a;
                                a=sc[i];
                                sc[i]=sc[j];
                                sc[j]=a;
                            }
                        }
                    }
                    for (int i = 1; i < n + 1; i++) {
                        System.out.println(sc[i]);
                    }
                    break;
                default :
                    System.out.println("exit");
                    loop = false;
            }
        }
    }
}

  分析如下:用循环提出身份证的日期比较日期的前后顺序,再进行排序。

剩下的题目我都没写,我觉得对我来说有点难。

3.踩坑总结

  第四次作业

    第十一次题目集的7-3我的代码运行超时,不知道怎么改。

    还有成绩统计的题目我一直都感觉不会做。

4.改进建议:

  (1)题目集要早点写,不然等下没时间写,不仅这次没做好,万一以后有迭代的题目就更做不出来。

  (2)写代码的时候要记得写注释,不然一大行代码在那里自己都可能看不懂,以后写总结的时候就很难总结。

  (3)要学会分析类与类之间的关系,先画类图再写代码。这样思路才清晰,更容易写对。

5.总结

  要早点写作业,不然做不完;不能看别人没写,我自己就不写了。不能认为法不责众。要先把题目读懂再做题,不然很难做出来。细节问题总是出错:像格式错误,读题不仔细这种

,确实是不应该犯的错误。也不应该觉得题目难我就不去写。