/* (程序头部注释开始)
* 程序的版权和版本声明部分
* Copyright (c) 2011, 烟台大学计算机学院学生
* All rights reserved.
* 文件名称:形状派生
* 作 者:张旭
* 完成日期: 2012 年 5 月 14 日
* 版 本 号:略
* 对任务及求解方法的描述部分
* 输入描述:略
* 问题描述:略
* 程序输出:略
* 程序头部的注释结束
*/
#include <iostream>
#include<string>
using namespace std;
double const PI = 3.1415926;
class Shape
{
public:
virtual double area () = 0;
};
class Circle:public Shape
{
private:
double r;
public:
virtual double area ()
{
return (PI * r * r);
}
Circle(double a):r(a){}
};
class Rectangle:public Shape
{
private:
double r1;
double r2;
public:
virtual double area ()
{
return (r1 * r2);
}
Rectangle(double a, double b):r1(a), r2(b){}
};
class Triangle:public Shape
{
private:
double t1;
double t2;
public:
virtual double area ()
{
return ((t1 * t2) / 2);
}
Triangle(double a, double b):t1(a), t2(b){}
};
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; //输出总面积
system("pause");
return 0;
}
运行结果:
totol of all areas=648.149
请按任意键继续. . .