第六周实验报告(四)

设计一个三角形类,能够输入三角形的三个顶点,求出其面积、周长,并判断其是否为直角三角形和等腰三角形。

提示:(1)这个问题需要用到两个类,顶点类参照任务3中的CPoint类;(2)三角形类参考下面CTriangle类的声明;(3)充分利用CPoint类中已有的代码实现;(4)关于三条边的处理,可以增加三个私有属性,在初始化时求出来备用,也可以在需要时计算得到。

 

#include <iostream>
#include <cmath>

using namespace std; 
 
class CPoint  
{  
      private:  
              double x;  
              double y;  
      public:  
             CPoint(double xx=0, double yy=0);//:x(xx),y(yy){}可以用另一种方法定义的   
             double Distance(CPoint p) const;  // 两点之间的距离(一点是当前点,另一点为参数P)                
             void input();                     //以x,y的形式 输入坐标点   
            void output();                    //以 (x,y)的形式输出坐标   
};
class CTriangle
{
      public:
             CTriangle(CPoint &x,CPoint &y, CPoint &z):A(x),B(y),C(z){}
             void setCTriangle(CPoint &x,CPoint &y,CPoint &z);
             double perimeter(void);         //计算三角形的周长
             double area(void);              //计算并返回三角形的面积
             bool isRightTriangle();        //是否为直角三角形
             bool isTsoscelesTriangle();    //为等腰三角形
      private:
              CPoint A,B,C;                 //三顶点
};
CPoint::CPoint(double xx,double yy)
{
                      x = xx;
                      y = yy;
}
void CPoint::input()  
{  
    char c;  
    cout<<"请输入坐标点(格式x,y ):";  
    while(1)  
    {  
      cin>>x>>c>>y;  
      if (c==',') break;  
        cout<<"输入错误,请重新输入\n";  
    }  
} 
void CTriangle::setCTriangle(CPoint &x,CPoint &y,CPoint &z)
{
     A = x;
     B = y;
     C = z;
}
void CPoint::output()  
{  
    cout<<"("<<x<<", "<<y<<")"<<endl;  
}
double CPoint::Distance(CPoint p) const  
{  
   double d;
     
    d=sqrt((p.x-x)*(p.x-x)+(p.y-y)*(p.y-y));
     
    return d;  
}
double CTriangle::perimeter() 
{
      double a,b,c;
      
      b=B.Distance(C);c=C.Distance(A);a=A.Distance(B);
      return (a+b+c);
}
double CTriangle::area()
{
    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)||(b*b+c*c)==(a*a))
     return true;
     else
     return false;
}
bool CTriangle::isTsoscelesTriangle()
{
     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;
}
int  main(void)  
{  
    CTriangle Tri1(CPoint(2,5),CPoint(5,2),CPoint(7,8));    //定义三角形类的一个实例(对象)     
    cout<<"该三角形的周长为:"<<Tri1.perimeter()<<",面积为:"<<Tri1.area()<<endl<<endl;  
    cout<<"该三角形"<<(Tri1.isRightTriangle()?"是":"不是")<<"直角三角形"<<endl;  
    cout<<"该三角形"<<(Tri1.isTsoscelesTriangle()?"是":"不是")<<"等腰三角形"<<endl;  
    system("pause");  
    return 0;
}  


 

经过这个题目我学会了,类中套类。好吧。但是这个程序还有一点错误啊。老师怎么解决。愁死我了

94 C:\Users\hp\Desktop\源程序库\任务4.cpp no matching function for call to `CTriangle::CTriangle(CPoint, CPoint, CPoint)'

望老师解决。

你可能感兴趣的:(c,Class,input,任务,output,distance)