/*
* 程序的版权和版本声明部分:
* Copyright (c) 2013, 烟台大学计算机学院
* All rights reserved.
* 文件名称:test.cpp
* 作 者:周经纬
* 完成日期:2014年 5月 27日
* 版 本 号:v12.1
* 项目
* 输入描述:无
* 问题描述:。
* 程序输出:
* 问题分析:略
* 算法设计:略
*/
#include <iostream>
#include <cstring>
using namespace std;
class Shape
{
public:
virtual double area()=0;
private:
};
class Circle:public Shape
{
public:
Circle(double a):r(a){}
~Circle(){};
double area()
{
return r*r*3.14;
}
private:
double r;
};
class Rectangle:public Shape
{
public:
Rectangle(double a,double b):chang(a),kuan(b){}
~Rectangle(){};
double area()
{
return chang*kuan;
}
private:
double chang;
double kuan;
};
class Triangle:public Shape
{
public:
Triangle(double a,double b):chang(a),kuan(b){}
~Triangle(){};
double area()
{
return chang*kuan/2;
}
private:
double chang;
double kuan;
};
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;
}
十四周项目二
最新推荐文章于 2023-08-13 19:33:25 发布