题意整理

  • 给定一个抽象类Base,里面定义了一个方法依赖于sum和avg这两个抽象方法。
  • 要求在Base的子类里实现这两个方法。

方法一(调用父类方法)

1.解题思路

  • 调用父类方法获取X、Y的值。
  • 在子类中,利用X、Y的值求它们的和以及平均值。

动图展示: alt

2.代码实现

import java.util.Scanner;

public class Main {

    public static void main(String[] args) {
        // Sub是需要你定义的子类
        Base base = new Sub();

        Scanner scanner = new Scanner(System.in);
        while (scanner.hasNextInt()) {
            int x = scanner.nextInt();
            int y = scanner.nextInt();
            base.setX(x);
            base.setY(y);
            System.out.println(base.calculate());
        }
    }

}

abstract class Base {

    private int x;
    private int y;

    public int getX() {
        return x;
    }

    public void setX(int x) {
        this.x = x;
    }

    public int getY() {
        return y;
    }

    public void setY(int y) {
        this.y = y;
    }

    public int calculate() {
        if (avg() == 0) {
            return 0;
        } else {
            return sum() / avg();
        }
    }

    /**
     * 返回x和y的和
     */
    public abstract int sum();

    /**
     * 返回x和y的平均值
     */
    public abstract int avg();

}
class Sub extends Base {
    
    //重写sum()方法
    @Override
    public int sum(){
        //调用父类方法获取X、Y的值,然后相加
        return super.getX()+super.getY();
    }
    
    //重写avg()方法
    @Override
    public int avg(){
        //调用父类方法获取X、Y的值,然后相加并除以2
        return (super.getX()+super.getY())/2;
    }

}

3.复杂度分析

  • 时间复杂度:sum()和avg()方法均只需进行一次运算,所以时间复杂度为O(1)O(1)O(1)
  • 空间复杂度:不需要额外的空间,所以空间复杂度为O(1)O(1)O(1)