定义一个具有多态性的基类Shape,继承以下一些类:圆Circle类(坐标点和半径构成)长方形Rectangle3.定义一个具有多态性的基类Shape,继承以下一些类:圆Circle类(坐标点和半径构成),长方形Rect
来源:学生作业帮助网 编辑:六六作业网 时间:2024/11/25 20:26:00
定义一个具有多态性的基类Shape,继承以下一些类:圆Circle类(坐标点和半径构成)长方形Rectangle3.定义一个具有多态性的基类Shape,继承以下一些类:圆Circle类(坐标点和半径构成),长方形Rect
定义一个具有多态性的基类Shape,继承以下一些类:圆Circle类(坐标点和半径构成)长方形Rectangle
3.定义一个具有多态性的基类Shape,继承以下一些类:圆Circle类(坐标点和半径构成),长方形Rectangle类(两个不重合的坐标点构成),三角形(Triangle)类(三个互不重合的坐标点构成).编程,按shape.txt文件内容创建各类对象,求其面积.若为圆,则还要输出其半径,(另用GetR函数实现,不是虚函数).
Shape.txt文件说明:
若第一个字符为’C’,则后面为圆数据:x坐标,y坐标,圆半径三个实数;
若第一个字符为’R’,则后面为长方形数据:x1,y1,x2,y2坐标;
若第一个字符为’T’,则后面为三角形数据:x1,y1,x2,y2,x3,y3坐标;
若第一个字符为’X’,表示输入结束.
###要可以运行出来的哦######跪谢~
定义一个具有多态性的基类Shape,继承以下一些类:圆Circle类(坐标点和半径构成)长方形Rectangle3.定义一个具有多态性的基类Shape,继承以下一些类:圆Circle类(坐标点和半径构成),长方形Rect
#include
#include
#include
#include
#define PI 3.14159
using namespace std;
class Shape
{
public:
virtual float getArea()=0;//纯虚函数
};
class Circle:public Shape
{
float x,y,r;
public:
Circle(float argx=0,float argy=0,float argr=0);
float getArea();
float getR();
};
Circle::Circle(float argx,float argy,float argr)
{
x=argx;y=argy;r=argr;
}
float Circle::getArea()
{
return PI*r*r;
}
float Circle::getR()
{
return r;
}
class Rectangle:public Shape
{
float x1,x2,y1,y2;
public:
Rectangle(float argx1=0,float argy1=0,float argx2=0,float argy2=0);
float getArea();
};
Rectangle::Rectangle(float argx1,float argy1,float argx2,float argy2)
{
x1=argx1;y1=argy1;x2=argx2;y2=argy2;
}
float Rectangle::getArea()
{
float length,width;
length=x1>x2 ? x1-x2 : x2-x1;
width=y1>y2 ? y1-y2 : y2-y1;
return length*width;
}
class Triangle:public Shape
{
float x1,x2,y1,y2,x3,y3;
public:
Triangle(float argx1=0,float argy1=0,float argx2=0,float argy2=0,float argx3=0,float argy3=0);
float getArea();
};
Triangle::Triangle(float argx1,float argy1,float argx2,float argy2,float argx3,float argy3)
{
x1=argx1;y1=argy1;x2=argx2;y2=argy2;x3=argx3;y3=argy3;
}
float Triangle::getArea()
{
float a,b,c,s;
//分别求三边
a=sqrt((x1-x2)*(x1-x2)+(y1-y2)*(y1-y2));
b=sqrt((x1-x3)*(x1-x3)+(y1-y3)*(y1-y3));
c=sqrt((x2-x3)*(x2-x3)+(y2-y3)*(y2-y3));
s=(a+b+c)/2;
return sqrt(s*(s-a)*(s-b)*(s-c)); //海伦公式求三角形面积
}
void main()
{
char shape;
Shape *ps;
float x1,y1,x2,y2,x3,y3,r;
ifstream inf("shape.txt");
if(!inf)
{
couty1>>r;
Circle c(x1,y1,r);
coutx2>>y2>>x3>>y3;
Triangle t(x1,y1,x2,y2,x3,y3);
cout