/*
* 程序的版权和版本声明部分
* Copyright (c)2013, 烟台大学计算机学院学生
* All rightsreserved.
* 文件名称:.cpp
* 作 者:王英华
* 完成日期:2014年5月27日
* 版本号: v1.0
* 对任务及求解方法的描述部分:略
* 输入描述:略
* 问题描述:略
*/#include<iostream>
#define pi 3.14
using namespace std;
class CSolid
{
public :
virtual double SurfaceArea() =0;
virtual double Volume() =0 ;
};
class CCube:public CSolid
{
public:
CCube(double len=0);
double SurfaceArea() ;
double Volume() ;
private:
double length;
};
CCube::CCube(double len)
{
length=len;
}
double CCube::SurfaceArea()
{
return 6*length*length;
}
double CCube::Volume()
{
return length*length*length;
}
class CBall:public CSolid
{
public:
CBall(double r=0) ;
double SurfaceArea() ;
double Volume() ;
private:
double radius;
};
CBall::CBall(double r)
{
radius=r;
}
double CBall::SurfaceArea()
{
return 4*pi*radius*radius;
}
double CBall::Volume()
{
return pi*radius*radius*radius*4/3;
}
class CCylinder:public CSolid
{
public:
CCylinder(double r=0,double high=0);
double SurfaceArea() ;
double Volume() ;
private:
double height,radius;
};
CCylinder::CCylinder(double r,double high)
{
radius=r;
height=high;
}
double CCylinder::SurfaceArea()
{
return 2*pi*radius*radius+2*pi*radius*height;
}
double CCylinder::Volume()
{
return pi*radius*radius*height;
}
int main()
{
CSolid *p;
double s,v;
CCube x(10);
cout<<"正方体边长为 10"<<endl;
p=&x;
s=p->SurfaceArea( );
v=p->Volume( );
cout<<"表面积:"<<s<<endl;
cout<<"体积:"<<v<<endl;
cout<<endl;
CBall y(1.2);
cout<<"球体半径为 1.2 "<<endl;
p=&y;
s=p->SurfaceArea( );
v=p->Volume( );
cout<<"表面积:"<<s<<endl;
cout<<"体积:"<<v<<endl;
cout<<endl;
CCylinder z(11,12);
cout<<"圆柱体底面半径、高分别为 11,12"<<endl;
p=&z;
s=p->SurfaceArea( );
v=p->Volume( );
cout<<"表面积:"<<s<<endl;
cout<<"体积:"<<v<<endl;
cout<<endl;
return 0;
}
运行结果: