/*
*Copyright (c) 2013 ,烟台大学计算机学院
*All rights reserved.
*作者:张凤宁
*完成日期:2014年5月28
*版本号:v1.0
*问题描述:
*样例输入:
*样例输出:
*问题分析:用简单的方法,学会活学活用
*/
#include <iostream>
#include <cmath>
using namespace std;
class Shape
{
public:
virtual float area()const
{
return 0.0;
};
};
class Circle:public Shape
{
public:
Circle(float r):radius(r) {};
virtual float area() const;
private:
float radius;
};
float Circle::area() const
{
return 3.14159*radius*radius;
}
class Rectangle:public Shape
{
public:
Rectangle(float l,float w):length(l),width(w) {};
virtual float area() const;
private:
float length;
float width;
};
float Rectangle::area()const
{
return length*width;
}
class Triangle:public Shape
{
public:
Triangle(float x,float h):a(x),height(h) {};
virtual float area()const;
private:
float a;
float height;
};
float Triangle::area()const
{
return (a*height)/2;
}
int main()
{
Circle c1(12.6),c2(4.9);//建立Circle类对象c1,c2,参数为圆半径
Rectangle r1(4.5,8.4),r2(5.0,2.5);//建立Rectangle类对象r1,r2,参数为矩形长、宽
Triangle t1(4.5,8.4),t2(3.4,2.8); //建立Triangle类对象t1,t2,参数为三角形底边长与高
Shape *pt[6]= {&c1,&c2,&r1,&r2,&t1,&t2}; //定义基类指针数组pt,使它每一个元素指向一个派生类对象
double areas=0.0; //areas为总面积
for(int i=0; i<6; i++)
{
areas=areas + pt[i]->area();
}
cout<<"totol of all areas="<<areas<<endl; //输出总面积
return 0;
}
运行结果:
<img src="https://img-blog.youkuaiyun.com/20140528192755937?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvdTAxMjM2OTc1Mg==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="" />