main函數
/*
* Copyright (c) 2013, 煙臺大學計算機學院
* All rights reserved.
* 作 者:紀麗娜
* 完成日期:2013 年04月2日
* 版 本 號:v1.0
* 問題描述:
回想Engineer類的數據成員,有眼鏡、揹包等。
某Engineer的眼鏡、揹包,是Glass、Bag類的對象。
類中的數據成員,其類型可以是簡單類型,也可以是類。
通過這種方式,將某些類組合到另外的類中,當作其中的一個“部件”使用。
本項目設計一個三角形類,其數據成員不再是三角形三條邊的邊長,
而是三角形的三個頂點。利用設計的三角形類,輸入三角形的三個頂點,
求出其面積、周長,並判斷其是否爲直角三角形和等腰三角形。
提示:
(1)這個問題需要用到兩個類,頂點類參照項目1中的CPoint類;
(2)三角形類參考下面CTriangle類的聲明;
(3)充分利用CPoint類中已有的代碼實現;
(4)關於三條邊的處理,可以增加三個私有屬性,
在初始化時求出來備用,也可以在需要時計算得到。
(5) 將項目2用“一個項目多個文件”的方式實現,
其中兩個類的聲明放在同一個.h文件中,
每個類的成員函數分別放一個文件,
main()函數用一個文件。體會這樣安排的優點。
*/
#include <iostream>
#include <Cmath>
#include "san.h"
using namespace std;
int main()
{
CPoint X(0,3),Y(4,0),Z(0,0);
CTriangle Tri1(X,Y,Z); //定義三角形類的一個實例(對象)
cout<<"該三角形的周長爲:"<<Tri1.perimeter()<<",面積爲:"<<Tri1.area()<<endl<<endl;
cout<<"該三角形"<<(Tri1.isRightTriangle()?"是":"不是")<<"直角三角形"<<endl;
cout<<"該三角形"<<(Tri1.isIsoscelesTriangle()?"是":"不是")<<"等腰三角形"<<endl;
return 0;
}
san.cpp函數
/*如果裏面有cout的話,前面加上#include<iostream>*/
#include <Cmath>
#include "san.h"
double CPoint::distance(CPoint p) const
{
double d;
d=sqrt((p.x-x)*(p.x-x)+(p.y-y)*(p.y-y));
return d;
}
void CTriangle::setTriangle(CPoint &X,CPoint &Y,CPoint &Z)
{
A=X;
B=Y;
C=Z;
}
double CTriangle::perimeter(void)
{
double a=B.distance(C),b=C.distance(A),c=A.distance(B);
return (a + b + c);
}
double CTriangle::area(void)
{
double a=B.distance(C),b=C.distance(A),c=A.distance(B);
double s =(a+b+c)/2;
return sqrt(s*(s-a)*(s-b)*(s-c));
}
bool CTriangle::isRightTriangle()//是否爲直角三角形
{
double a=B.distance(C),b=C.distance(A),c=A.distance(B);
if((a*a+b*b==c*c)||(a*a+c*c==b*b)||(c*c+b*b==a*a))
return true;
else
return false;
}
bool CTriangle::isIsoscelesTriangle() //是否爲等腰三角形
{
double a=B.distance(C),b=C.distance(A),c=A.distance(B);
if((a==b)||(b==c)||(a==c))
return true;
else
return false;
}
san.h
#ifndef SAN_H_INCLUDED
#define SAN_H_INCLUDED
class CPoint
{
private:
double x; // 橫座標
double y; // 縱座標
public:
CPoint(double xx=0,double yy=0):x(xx),y(yy){}
double distance(CPoint p) const; // 兩點之間的距離
};
class CTriangle
{
public:
CTriangle(CPoint &X,CPoint &Y,CPoint &Z):A(X),B(Y),C(Z){} //給出三點的構造函數
void setTriangle(CPoint &X,CPoint &Y,CPoint &Z);//
double perimeter(void);//計算三角形的周長
double area(void);//計算並返回三角形的面積
bool isRightTriangle(); //是否爲直角三角形
bool isIsoscelesTriangle(); //是否爲等腰三角形
private:
CPoint A,B,C; //三頂點
};
#endif // SAN_H_INCLUDED
兩個要打上勾,要構成san.cpp和san.h的關聯關係!!!!!!!!!!