第13周项目四——立体族类共有的抽象类

/*    
*烟台大学计算机学院    
*文件名称:xiangmu1.cpp    
*作    者:李亚辉    
*完成日期:2016年6月23日    
*版 本 号:vc++6.0   
*    
*问题描述:设计一个抽象类CSolisd,含有用于求表面积及体积的两个纯虚数,并设计派生类,求表面积与体积  
*输入描述:长宽高等数值 
*程序输出:定义的几个几何体的表面积与体积
*/  
#include "iostream"  
using namespace std;  
  
const double pai=3.1415926;  
// 抽象立体图形基类  
class CSolid  
{  
public:  
    virtual double SurfaceArea() const=0;  
    virtual double Volume() const=0;  
};  
  
// 立方体类  
class CCube : public CSolid  
{  
public:  
    CCube(double len=0);  
    double SurfaceArea() const;   // 求表面积  
    double Volume() const;        // 求体积  
private:  
    double length;  
  
};  
  
// 立方体类构造函数  
CCube::CCube(double len)  
{  
    length=len;  
}  
  
// 求立方体表面积  
double CCube::SurfaceArea() const  
{  
    double c;  
    c=6*length*length;  
    return c;  
}  
  
// 求立方体体积  
double CCube::Volume() const  
{  
    double c;  
    c=length*length*length;  
    return c;  
}  
  
// 球体类  
class CBall : public CSolid  
{  
private:  
    double radius;            // 圆周率  
public:  
    CBall(double r=0);  
    double SurfaceArea() const;  // 求表面积  
    double Volume() const;       // 求体积;  
};  
  
// 球体类构造函数  
CBall::CBall(double r)  
{  
    radius=r;  
}  
  
// 求球体表面积  
double CBall::SurfaceArea() const  
{  
    double c;  
    c=4*pai*radius*radius;  
    return c;  
}  
  
// 求球体体积  
double CBall::Volume() const  
{  
    double c;  
    c=pai*radius*radius*radius*4/3;  
    return c;  
}  
  
// 圆柱体类  
class CCylinder : public CSolid  
{  
private:  
        double radius;  
    double height;  
public:  
    CCylinder(double r=0,double high=0);  
    double SurfaceArea() const;       // 求表面积  
    double Volume() const;            // 求体积  
};  
  
// 圆柱体类构造函数  
CCylinder::CCylinder(double r,double high)  
{  
    radius=r;  
    height=high;  
}  
  // 求圆柱体表面积  
double CCylinder::SurfaceArea() const  
{  
    double c;  
    c=2*pai*radius*radius+2*pai*radius*height;  
    return c;  
}  
// 求圆柱体体积  
double CCylinder::Volume() const  
{  
    double c;  
    c=pai*radius*radius*height;  
    return c;  
}  
  
int main( )  
{  
    CSolid *p;  
    double s,v;  
    CCube x(30);  
    cout<<"立方体边长为 30 "<<endl;  
    p=&x;  
    s=p->SurfaceArea( );  
    v=p->Volume( );  
    cout<<"表面积:"<<s<<endl;  
    cout<<"体积:"<<v<<endl;  
    cout<<endl;  
    CBall y(4.5);  
    cout<<"球体半径为 4.5 "<<endl;  
    p=&y;  
    s=p->SurfaceArea( );  
    v=p->Volume( );  
    cout<<"表面积:"<<s<<endl;  
    cout<<"体积:"<<v<<endl;  
    cout<<endl;  
    CCylinder z(10,20);  
    cout<<"圆柱体底面半径、高分别为 10, 20"<<endl;  
    p=&z;  
    s=p->SurfaceArea( );  
    v=p->Volume( );  
    cout<<"表面积:"<<s<<endl;  
    cout<<"体积:"<<v<<endl;  
    cout<<endl;  
<img src="https://img-blog.csdn.net/20160623224238989?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="" />

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值