허함수를 이용하여 면적을 구하다

2250 단어

허함수를 이용하여 면적을 구하다


제목.


Circle(원형), Rectangle(직사각형), Triangle(삼각형) 등 3개의 파생 클래스를 생성하는 추상 베이스 Shape을 정의합니다.베이스 포인터 벡터를 사용하여 각 요소가 파생 클래스의 그래픽 객체를 가리키는 구면적 및 함수 double TotalArea(const vector &)를 작성합니다.테스트 해석기를 작성하고 각종 도형 정보를 읽으며 동적 생성 각종 도형 대상을 vector에서 관리합니다.면적 허함수를 이용하여 면적 총화를 출력하고 공간을 정확하게 방출해야 한다.PI는 3.1416.
설명 입력
circle 뒷굽 반경 rectangle 뒷굽 길이와 너비 triangle 뒷굽 세 변
출력 설명
결과 소수점 이하 4자리 유지
샘플 입력
circle 5.2 circle 6.0 rectangle 3.42 triangle 3 4 5 rectangle 4.410 샘플 출력
254.8465

코드

#include
#include
#include
#include
#include 
#define PI 3.1416
using namespace std;
class Shape
{
public:
	virtual ~Shape() { }
	virtual double GetArea() const = 0;
};
class Circle: public Shape
{
private:
	double radius;
public:
	Circle(double r): radius(r) {}
	double GetArea() const { return PI * radius * radius; }
};
class Rectangle: public Shape
{
private:
	double height;
	double width;
public:
	Rectangle(double h, double w): height(h), width(w) { }
	double GetArea() const { return height * width; }
};
class Trangle:public Shape
{
	private:
		double e1, e2, e3;
	public:
		Trangle(double a, double b, double c):e1(a), e2(b), e3(c) {}
		double GetArea() const
		{
			double p=(e1+e2+e3)/2;
			return sqrt(p*(p-e1)*(p-e2)*(p-e3));
		}
};
double TotalArea (vector jojo)// , 
{
	double sum=0;
	for(int i=0;iGetArea();
		delete jojo[i];// , , 
		sum+=Area;
	}
	return sum;
}
int main(void)
{
	Shape *p;
	vector jojo;
	char s[10];
	double r;
	double c, k;
	double e1, e2, e3;
	int num=1;
	while(cin>>s)
	{
		//cin>>s;
		if(!strcmp(s, "circle"))
		{
			cin>>r;
			p=new Circle(r);
			jojo.push_back(p);
		}
		else if(!strcmp(s, "rectangle"))
		{
			cin>>c>>k;
			p=new Rectangle(c, k);
			jojo.push_back(p);
			//delete p;
		}
		else if(!strcmp(s, "triangle"))
		{
			cin>>e1>>e2>>e3;
			p=new Trangle(e1, e2, e3);
			jojo.push_back(p);
			//delete p;
		}
	}
	printf("%.4f", TotalArea(jojo));
	jojo.clear();
}

좋은 웹페이지 즐겨찾기