/*
* Copyright (c)2013, 烟台大学计算机学院学生
* All rightsreserved.
* 文件名称: array.cpp
* 作 者: 李中意
* 完成日期:2014 年 5月 27 日
* 版本号: v1.0
* 输入描述:无
*/
#include <iostream>
#include <iomanip>
#define PI 3.1415926
using namespace std;
class Shape
{
public:
virtual float area() const{return 0;}
};
class Circle:public Shape
{
public:
Circle(float r):radious(r){}
virtual float area() const
{
return (PI*radious*radious);
}
protected:
float radious;
};
class Square:public Shape
{
public:
Square(float a):at(a){}
virtual float area() const
{
return (at*at);
}
protected:
float at;
};
class Rectangle:public Shape
{
public:
Rectangle(float l,float w):length(l),width(w){}
virtual float area() const
{
return (length*width);
}
protected:
float length,width;
};
class Trapezoid:public Shape //梯形
{
public:
Trapezoid(float w1,float w2,float h):sd(w1),xd(w2),heigh(h){}
virtual float area() const
{
float s;
s=(sd+xd)*heigh/2;
return s;
}
protected:
float sd,xd,heigh;
};
class Triangle:public Shape //三角形
{
public:
Triangle(float w,float h):wa(w),heigh(h){}
virtual float area() const
{
return wa*heigh/2;
}
protected:
float wa,heigh;
};
int main()
{
float r,a,b,w1,w2,w,h;
cout<<fixed<<setprecision(2);
cin>>r;
Circle circle(r);
cin>>a;
Square square(a);
cin>>a>>b;
Rectangle rectangle(a,b);
cin>>w1>>w2>>h;
Trapezoid trapezoid(w1,w2,h);
cin>>w>>h;
Triangle triangle(w,h);
Shape *pt[5]= {&circle,&square,&rectangle,&trapezoid,&triangle};
double areas=0.0;
for(int i=0; i<5; i++)
areas=areas+pt[i]->area();
cout<<"total of all areas="<<areas<<endl;
return 0;
}