第13周实验报告3

/* (程序头部注释开始)       
* 程序的版权和版本声明部分       
* 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
请按任意键继续. . .


 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值