/*
*程序的版权和版本声明部分:
*Copyright(c)2013,烟台大学计算机学院学生
*All rights reserved.
*文件名称:
*作者:尚振伟
*完成日期:2014年5月27日
*版本号:v0.1
*对任务及求解方法的描述部分:
*输入描述:无
*问题描述:编写一个程序,定义抽象基类Shape,由它派生出5个派生类: Circle(圆形)、Square(正方形)、Rectangle(矩形)、Trapezoid(梯形)、Triangle(三角形)。
用虚函数分别计算几种图形面积,并求它们之和。
要求用基类指针数组,使它每一个元素指向一个派生类对象。
*程序输入:
*程序输出:
*问题分析:
*算法设计:
*我的程序:
*/
#include <iostream>
#include <iomanip>
using namespace std;
class Shape
{
public:
virtual double area() =0;
};
class Circle:public Shape
{
public:
Circle(double rr):r(rr) {}
virtual double area()
{
return 3.1415926*r*r;
}
private:
float r;
};
class Square:public Shape
{
public:
Square(float aa):a(aa) {}
virtual double area()
{
return a*a;
}
private:
float a;
};
class Rectangle:public Shape
{
public:
Rectangle(float l,float w):length(l),width(w) {}
virtual double area()
{
return length*width;
}
private:
float length;
float width;
};
class Trapezoid:public Shape
{
public:
Trapezoid(float sd1,float xd1,float hh):sd(sd1),xd(xd1),heigh(hh) {}
virtual double area()
{
return (sd+xd)*heigh/2;
}
private:
float sd;
float xd;
float heigh;
};
class Triangle:public Shape
{
public:
Triangle(float l,float h):len(l),height(h) {}
virtual double area()
{
return (len*height)/2;
}
private:
float len;
float height;
};
int main()
{
float r,a,b,w1,w2,w,h;
cout<<fixed<<setprecision(2);
cin>>r;
Circle circle(r);
cin>>a;
Square square(a);
cin>>a>>b;
Rectangle rectangle(a,b);
cin>>w1>>w2>>h;
Trapezoid trapezoid(w1,w1,h);
cin>>w>>h;
Triangle triangle(w,h);
Shape *pt[5]= {&circle,&square,&rectangle,&trapezoid,&triangle};
double areas=0.0;
for(int i=0; i<5; i++)
{
areas=areas+pt[i]->area();
}
cout<<"total of all areas="<<areas<<endl;
return 0;
}
结果展示:
心得体会:现在终于知道为啥在OJ上提交老是出现错误了。