zoukankan      html  css  js  c++  java
  • java 期末考试复习

     
     

    //Scanner这样写?

    Scanner input = new Scanner(System.in);

     

    //不断获得下一个单词

    names[i] = toTitleCase(input.next());

     

    inheritance

    • Constructors are inherited, but use super() 

     

    public class Parent { public Parent() {
    do some code; }
    }
    public class Child extends Parent {
    public Child() {
    super(); // call Parent() do some more code;
    } }
    so in a main method:
    Child c = new Child(); // Calls Parent(), too

     

    Default constructor == no parameters 

    第72页,子类能加新方法吗?

     

    只有public方法的可以override,别的几个关键字都不行
     
    exam1:
    //yuec2 yue cheng
    package exam1;
    
    //import java.io.File;
    import java.io.FileNotFoundException;
    import java.io.FileReader;
    import java.util.Scanner;
    
    public class ScoreBoard {
        String[] players;
        int[][] playerScores;
        Scanner input = new Scanner(System.in);
        
        //do not change this method
        public static void main(String[] args) {
            ScoreBoard scoreBoard = new ScoreBoard();
            scoreBoard.readScores("GameScores.txt");
            scoreBoard.showScores(scoreBoard.getMenuChoice());
        }
        
        //do not change this method
        int getMenuChoice() {
            System.out.println("*** Score Board ***");
            System.out.println("1. List all the scores of a player");
            System.out.println("2. Find a player's average score");
            System.out.println("3. Find all highest scores"); 
            System.out.println("4. Exit");
            int choice = input.nextInt();
            input.nextLine();
            return choice;
        }
        
        void readScores(String filename) {
            //write your code here
            try {
                int counts=0;
                Scanner sc = new Scanner((new FileReader("GameScores.txt")));
                while(sc.hasNextLine()) {
                     sc.nextLine();
                     counts++;}
            players = new String[counts];
            playerScores = new int[counts][];
            sc = new Scanner((new FileReader("GameScores.txt")));
            for(int i=0; i< counts; i++) {
                String thisline= sc.nextLine();
                players[i] = thisline.split(":")[0].trim();
                String[] temp = thisline.split(":")[1].trim().split(",");
                int size = temp.length;
                playerScores[i] = new int[size];
                for (int j = 0; j < size; j++) {
                    playerScores[i][j] = Integer.valueOf(temp[j].trim());
                }
            }        
            }
                
                catch (FileNotFoundException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
        }
        
        void showScores(int choice) {
            //write your code here
            if (choice == 1) {
                String name = input.nextLine();
                findPlayerScores(name);
            }else if (choice == 2) {
                String name = input.nextLine();
                findPlayerAverageScore(name);
            }else if (choice == 3) {
                findAllHighestScores();
            }else if (choice == 4) {
                System.out.println("Good bye!");
            } 
            return ;
        }
    
        int[] findPlayerScores(String name) {
            //write your code here
            int index = -1;
            for (int i = 0; i < players.length; i++) {
                //System.out.println("players[i] = " + players[i]);
                if (players[i].toLowerCase().equals(name.toLowerCase())) index = i;
                }
            //corner case
            if (index == -1) return null;
            //System.out.println("index = " + index);
            //System.out.println(players[index] +"'s scores
    ");
            for (int j = 0; j < playerScores[index].length; j++) {
                System.out.println(playerScores[index][j]);
            }
            return playerScores[index];
        }
        
        float findPlayerAverageScore(String name) {
            //write your code here
            int[] scores = findPlayerScores(name);
            float sum = 0;
            for(int i = 0; i < scores.length; i++) {
                sum += scores[i];
            }
            System.out.printf("%s's average score is %.2f", name, sum / scores.length);
            return sum / scores.length;
        }
        
        int[] findAllHighestScores() {
            //write your code here
            int[] highestScores = new int[players.length];
            int max = Integer.MIN_VALUE;
            for (int i = 0; i < players.length; i++) {
                int size = playerScores[i].length;
                for (int j = 0; j < size; j++) {
                    max = Math.max(max, playerScores[i][j]);
                    //System.out.println("max = " + max);
                }
                highestScores[i] = max;
                max = Integer.MIN_VALUE;
                System.out.println(highestScores[i]);
            }
            return highestScores;
            //return null;
        }
    }
    View Code

    //里面的参数竟然是FileReader

    Scanner sc = new Scanner((new FileReader("GameScores.txt")));

     

    /就改个这里就行了 .toLowerCase()

     

    System.out.println //自动竖行分隔

     

    //不能这样用,因为里面有打印,要再写一遍

    //int[] scores = findPlayerScores(name);

     

     

    System.out.printf("%s's average score is %.2f", name, sum / scores.length);

    //打印和返回分开?不应该啊

    return (float)sum / scores.length;

     

     

    for (int i = 0; i < players.length; i++) {

    //max的定义必须在循环里面啊

     exam2

    Caesar

    //yuec2 Yue Cheng
    package exam2;
    
    public class Caesar extends Message{
    
        Caesar(String text, String key) {
            super(text, key);
            // TODO Auto-generated constructor stub
        }
    
        @Override
        public String encrypt() {
            // TODO Auto-generated method stub
            //handle the return case
            int keyNumber = Integer.valueOf(key);
            StringBuilder encryptedSb = new StringBuilder();
            for (int i = 0; i < text.length(); i++) {
                char charToEncrypt = text.charAt(i);
                char encryptedChar = (char) (charToEncrypt + keyNumber);
                if (encryptedChar > 'Z') 
                    encryptedChar = (char) (encryptedChar + ('A' - 'Z' -1));
                encryptedSb.append(encryptedChar);
            }
            return encryptedSb.toString();
        }
    
        @Override
        public String decrypt() {
            // TODO Auto-generated method stub
            int keyNumber = Integer.valueOf(key);
            StringBuilder decryptedSb = new StringBuilder();
            for (int i = 0; i < text.length(); i++) {
                char charToDecrypt = text.charAt(i);
                System.out.println("charToDecrypt = " + charToDecrypt);
                char decryptedChar = (char) ((int)charToDecrypt - keyNumber);
                //wrong
                System.out.println("decryptedChar1 = " + decryptedChar);
                if (decryptedChar > 'Z') 
                    decryptedChar = (char) (decryptedChar + ('A' - 'Z' - 1));
                
                decryptedSb.append(decryptedChar);
            }
            return decryptedSb.toString();
        }
    
        @Override
        boolean validateInput() {
            // TODO Auto-generated method stub
            text = text.toUpperCase();
            for (int i = 0; i < text.length(); i++) {
                if (text.charAt(i) < 'A' || text.charAt(i) > 'Z')
                    return false;
            }
            //text = text.toLowerCase();
            //get all digist in key to numbers
            //Integer number = Integer.valueOf(key);
            for (int i = 0; i < key.length(); i++) {
                int digit = Integer.valueOf(key.charAt(i));
                if (digit < 0 || digit > 9) return false;
            }
            return true;
        }
    
    }
    View Code

    Keyword

    //yuec2 Yue Cheng
    package exam2;
    
    public class Keyword extends Message{
    
        Keyword(String text, String key) {
            super(text, key);
            // TODO Auto-generated constructor stub
        }
    
        @Override
        public String encrypt() {
            // TODO Auto-generated method stub
            char[] keyChars = key.toCharArray();
            StringBuilder encryptedSb = new StringBuilder();
            //handle the repeat case
            //correct
            //System.out.println("text.length()="+ text.length());
            for (int i = 0; i < text.length(); i++) {
                //if (i == keyChars.length - 1) i = 0;
                char charToEncrypt = text.charAt(i);
                //System.out.println("charToEncrypt="+ charToEncrypt);
                char encryptedChar = (char) (charToEncrypt + (keyChars[i] % 'A' + 1));
                if (encryptedChar > 'Z') 
                    encryptedChar = (char) (encryptedChar + ('A' - 'Z' -1));
                //System.out.println("encryptedChar="+ encryptedChar);
                encryptedSb.append(encryptedChar);
            }
            return encryptedSb.toString();
        }
    
        @Override
        public String decrypt() {
            // TODO Auto-generated method stub
            char[] keyChars = key.toCharArray();
            StringBuilder decryptedSb = new StringBuilder();
            //handle the repeat case
            for (int i = 0; i < text.length(); i++) {
                //if (i == keyChars.length - 1) i = 0;
                char charToDecrypt = text.charAt(i);
                char decryptedChar = (char) (charToDecrypt - (keyChars[i] % 'A' + 1));
                //wrong
                System.out.println("decryptedChar1="+decryptedChar);
                if (decryptedChar > 'Z') 
                    decryptedChar = (char) (decryptedChar + ('A' - 'Z' -1));
                System.out.println("decryptedChar2="+decryptedChar);
                decryptedSb.append(decryptedChar);
            }
            System.out.println("decryptedSb.toString()="+decryptedSb.toString());
            return decryptedSb.toString();
        }
    
        @Override
        boolean validateInput() {
            // TODO Auto-generated method stub
            text = text.toUpperCase();
            for (int i = 0; i < text.length(); i++) {
                if (text.charAt(i) < 'A' || text.charAt(i) > 'Z') 
                    return false;
            }
            
            key = key.toUpperCase();
            for (int i = 0; i < key.length(); i++) {
                if (key.charAt(i) < 'A' || key.charAt(i) > 'Z') 
                    return false;
            }
            return true;
        }
    
    }
    View Code

    //转格式要加到try catch中

    int keyNumber;
            try{
                keyNumber = Integer.valueOf(key);
            }catch(NumberFormatException ex){ // handle your exception
                keyNumber = 0;
            }

     exam3:

    关键字this 是用来指向当前对象或类实例的

    抽象类和接口的对比

    参数 抽象类 接口
    默认的方法实现 它可以有默认的方法实现 接口完全是抽象的。它根本不存在方法的实现
    实现 子类使用extends关键字来继承抽象类。如果子类不是抽象类的话,它需要提供抽象类中所有声明的方法的实现。 子类使用关键字implements来实现接口。它需要提供接口中所有声明的方法的实现
    构造器 抽象类可以有构造器 接口不能有构造器
    与正常Java类的区别 除了你不能实例化抽象类之外,它和普通Java类没有任何区别 接口是完全不同的类型
    访问修饰符 抽象方法可以有publicprotecteddefault这些修饰符 接口方法默认修饰符是public。你不可以使用其它修饰符。
    main方法 抽象方法可以有main方法并且我们可以运行它 接口没有main方法,因此我们不能运行它。
    多继承 抽象方法可以继承一个类和实现多个接口 接口只可以继承一个或多个其它接口
    速度 它比接口速度要快 接口是稍微有点慢的,因为它需要时间去寻找在类中实现的方法。
    添加新方法 如果你往抽象类中添加新的方法,你可以给它提供默认的实现。因此你不需要改变你现在的代码。 如果你往接口中添加方法,那么你必须改变实现该接口的类。

    什么时候使用抽象类和接口

    • 如果你拥有一些方法并且想让它们中的一些有默认实现,那么使用抽象类吧。
    • 如果你想实现多重继承,那么你必须使用接口。由于Java不支持多继承,子类不能够继承多个类,但可以实现多个接口。因此你就可以使用接口来解决它。
    • 如果基本功能在不断改变,那么就需要使用抽象类。如果不断改变基本功能并且使用接口,那么就需要改变所有实现了该接口的类。

     EXAM3

    //override the hashcode method

    //按照name来对object进行哈希

    public int hashCode(){

    return Objects.hash(name);

    }

     

     

    //hash物体的equals必须这么写,只有比较的参数:name最重要

    public boolean equals(Object o){

    if (o == null) return false;

    if (this == o) return true;// make sure they

    //are not pointing to the same location

    if (getClass() != o.getClass()) return false;

    Member m  = (Member) o;

    //compare by name

    if(name.equals(m.name)) return true;

    else return false;

    }

     

     

    //用this关键字代表当前object

    String name = this.members[i];

     

     

    //有点忘了还能这么写

    Collections.sort(memberList);

     

     

    //排序一开始就建好了

    Collections.sort(memberList);

    TreeMap<String, List<String>> MemberMap = new TreeMap<>();

     

  • 相关阅读:
    JS事件冒泡、事件捕获和事件委托
    实现英文字母排序
    JavaScript异步加载的四种方法
    JavaScript作用域与作用域链
    JavaScript 自定义属性 data-*
    asycn和await
    style collectd
    JavaScript如何比较两个数组的内容是否相同
    VScode插件开发--M2D文档转换插件
    BOM笔记
  • 原文地址:https://www.cnblogs.com/immiao0319/p/10090591.html
Copyright © 2011-2022 走看看