计算长方体、四棱锥的表面积和体积

版权声明:正在学习中,有错误欢迎指出。感谢比❤❤~ https://blog.csdn.net/gx17864373822/article/details/79954116

Problem Description
这里写图片描述
从图中观察,可抽取其共同属性到父类Rect中:长度:l 宽度:h 高度:z

在父类Rect中,定义求底面周长的方法length( )和底面积的方法area( )。

定义父类Rect的子类立方体类Cubic,计算立方体的表面积和体积。其中表面积area( )重写父类的方法。

定义父类Rect的子类四棱锥类Pyramid,计算四棱锥的表面积和体积。其中表面积area( )重写父类的方法。

输入立体图形的长(l)、宽(h)、高(z)数据,分别输出长方体的表面积、体积、四棱锥的表面积和体积。

Input
输入多行数值型数据(double);

每行三个数值,分别表示l h z

若输入数据中有非正数,则不表示任何图形,表面积和体积均为0。

Output
行数与输入相对应,数值为长方体表面积 长方体体积 四棱锥表面积 四棱锥体积(中间有一个空格作为间隔,数值保留两位小数)

Sample Input
1 2 3
0 2 3
-1 2 3
3 4 5
Sample Output
22.00 6.00 11.25 2.00
0.00 0.00 0.00 0.00
0.00 0.00 0.00 0.00
94.00 60.00 49.04 20.00
Hint
四棱锥体公式:V=1/3Sh,S——底面积 h——高

package pp;
import java.util.*;
class Rect{//父类
    double l, h, z;

    public Rect(double l, double h, double z) {
        super();
        if(l > 0 && h > 0 && z > 0) {//>0才表示图形
            this.l = l;
            this.h = h;
            this.z = z;
        }
    }
    public Rect() {

    }

    public double area() {
        return this.l*this.h;
    }
    public double length() {
        return 2*(this.l+this.h);
    }
}

class Cubic extends Rect{//长方体
    public Cubic(double l, double h, double z) {
        super(l, h, z);
    }
    public double area() {//表面积
        return super.area()*2 + super.length()*super.z;
    }
    public double vol(){  
            return super.area()*z;  
    }  
}

class Pri extends Rect{//四棱锥
    public Pri(double l, double h, double z){  
        super(l, h, z);  
    }  
    public double area(){  
        return super.area() +super.h*Math.sqrt(super.z*super.z  + super.l*super.l/4) +super.l * Math.sqrt(super.z*super.z  + super.h*super.h/4);  

    }  
    public double vol(){  
        return super.area()*z/3;  
    }  
}

public class Main {

    public static void main(String[] args){
        Scanner sc = new Scanner(System.in);
        while(sc.hasNext()) {
            double l = sc.nextDouble();
            double h = sc.nextDouble();
            double z = sc.nextDouble();
            Cubic c = new Cubic(l, h, z);
            Pri p = new Pri(l, h, z);
            System.out.printf("%.2f %.2f %.2f %.2f\n", c.area(), c.vol(), p.area(), p.vol());
        }
        sc.close(); 
    }
}
阅读更多
想对作者说点什么?

博主推荐

换一批

没有更多推荐了,返回首页