jmu-Java-03面向对象基础-04-形状-继承
前言 【编程习题集|JAVA-jmu-Java-03面向对象基础-04-形状-继承】前面题目形状中我们看到,为了输出所有形状的周长与面积,需要建立多个数组进行多次循环。这次试验使用继承与多态来改进我们的设计。
本题描述
1.定义抽象类Shape 属性:不可变静态常量double PI,值为3.14,
抽象方法:public double getPerimeter(),public double getArea()
2.Rectangle与Circle类均继承自Shape类。 Rectangle类(属性:int width,length)、Circle类(属性:int radius)。
带参构造方法为Rectangle(int width,int length),Circle(int radius)。
toString方法(Eclipse自动生成)
3.编写double sumAllArea方法计算并返回传入的形状数组中所有对象的面积和与double sumAllPerimeter方法计算并返回传入的形状数组中所有对象的周长和。
4.main方法 4.1 输入整型值n,然后建立n个不同的形状。如果输入rect,则依次输入宽、长。如果输入cir,则输入半径。
4.2 然后输出所有的形状的周长之和,面积之和。并将所有的形状信息以样例的格式输出。 提示:使用Arrays.toString。
4.3 最后输出每个形状的类型与父类型.使用类似shape.getClass() //获得类型, shape.getClass().getSuperclass() //获得父类型;
注意:处理输入的时候使用混合使用nextInt与nextLine需注意行尾回车换行问题。
输入样例:
4
rect
3 1
rect
1 5
cir
1
cir
2
输出样例:
38.84
23.700000000000003
[Rectangle [width=3, length=1], Rectangle [width=1, length=5], Circle [radius=1], Circle [radius=2]]
class Rectangle,class Shape
class Rectangle,class Shape
class Circle,class Shape
class Circle,class Shape
代码:
import java.util.Scanner;
abstract class Shape {
final static double PI = 3.14;
public abstract double getPerimeter();
public abstract double getArea();
}
class Rectangle extends Shape {
int width, length;
public Rectangle(int width,int length)
{ this.width = width;
this.length = length;
}
public double getPerimeter()
{ return (width+length)*2;
}
public double getArea()
{ return width*length;
}
public String toString()
{ String msg = String.format("Rectangle [width=%d, length=%d]",width,length);
return msg;
}
}
class Circle extends Shape{
int radius;
public Circle(int radius)
{ this.radius = radius;
}
public double getPerimeter()
{ return 2*PI*radius;
}
public double getArea()
{ return PI*radius*radius;
}
public String toString()
{ String msg = String.format("Circle [radius=%d]",radius);
return msg;
}
}public class Main {
public static double sumAllArea(Shape[] shapes) {
double sum = 0;
for (int i = 0;
i < shapes.length;
i++)
{ sum += shapes[i].getArea();
}
return sum;
}
public static double sumAllPerimeter(Shape[] shapes) {
double sum = 0;
for (int i = 0;
i < shapes.length;
i++)
{ sum += shapes[i].getPerimeter();
}
return sum;
}public static void main(String[] args) {
Scanner input = new Scanner(System.in);
int n = input.nextInt();
Shape[] shapes = new Shape[n];
for(int i=0;
i
推荐阅读
- 分布式|分布式理论总览
- python|四、python基础——基本结构语句&&函数和模块
- python|二、python基础——语法规则和编程命名规范
- #|基于改进的蚂蚁群算法求解最短路径问题、二次分配问题、背包问题【Matlab&Python代码实现】
- #|无线电信号调制【小波去噪】(Matlab&Python代码实现)
- #|基于粒子群算法的电力系统无功优化研究(IEEE14节点)(Matlab代码实现)
- Java|大厂面经分享(双非五面入职字节,他都做了哪些准备())
- 面试文|【面经分享】两年经验拿到PingCAP Offer
- 设计模式|GO 常用设计模式