6-5

本文展示了如何使用C++实现不同几何形状(圆形、矩形、三角形、正方形和梯形)的面积计算,并通过一个函数对这些形状的面积进行求和。
#include <iostream.h>
class Shape{
public:
	virtual double area()const =0;
};
class Circle:public Shape
{
public:
	Circle(double r):radius(r){}
	virtual double area() const
	{
	 return 3.1415*radius*radius;
	}
protected:
	double radius;
};
class Rectangle :public Shape{
public:
	Rectangle(double l,double w):length(l),width(w){}
	virtual double area()const
	{
	 return length*width;
	}
protected:
	double length;
	double width;
};
class Triangle:public Shape
{
public:
	Triangle(double d,double h):dibian(d),height(h){}
	virtual double area() const
	{
	 return 0.5*dibian*height;
	}
protected:
	double dibian;
	double height;
};
class Square:public Shape{
public:
	Square(double s):side(s){}
	virtual double area() const
	{
	 return side*side;
	}
protected:
	double side;
};
class Trapezoid:public Shape
{
public:
	Trapezoid(double t,double b,double h):top(t),bottem(b),height(h){}
	virtual double area() const
	{
	 return 0.5*(top+bottem)*height;
	}
protected:
	double top,bottem,height;
};
void display(const Shape &s)
{
 cout<<s.area()<<endl;
}
int main()
{
 Circle c(4);
 Rectangle r(2,4);
 Triangle t(1,2);
 Square s(2);
 Trapezoid tt(1,2,3);
 Shape *p[5]={&c,&r,&t,&s,&tt};
 double area=0.0;
 for(int i=0;i<5;i++)
 {
  area=area+p[i]->area();
 }
 cout<<"the sum of area is "<<area<<endl;
 return 0;
}
<img src="https://img-blog.youkuaiyun.com/20150616194739894?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvaV8zdW1tZXI=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="" />

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值