三角形的类,坐标

/*
*Corpyright (c)2013,烟台大学计算机学院
*All right reseved.
*作者:张梦佳
*完成日期:2014年4月1日
*版本号:v1.0
*输入描述:
*问题描述:类的指针!const 的坐标应用
*程序输出:
*问题分析:
*算法设计:
*/

#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;
 }
  void input(double,double);
  double Distance1(CPoint p) const;   // 两点之间的距离(一点是当前点,另一点为参数p)
  CPoint SymmetricAxis(char style) const;//style取'x','y'和'o'分别表示按x轴, y轴, 原点对称
};
class CTriangle
{
public:
  CTriangle(CPoint &X,CPoint &Y,CPoint &Z):A(X),B(Y),C(Z){} //给出三点的构造函数
  void setTriangle(CPoint &X,CPoint &Y,CPoint &Z);//
  float perimeter(void);//计算三角形的周长
  float area(void);//计算并返回三角形的面积
  bool isRightTriangle(); //是否为直角三角形
  bool isIsoscelesTriangle(); //是否为等腰三角形
private:
  CPoint A,B,C; //三顶点
  double s1,s2,s3;
};
float CTriangle::perimeter(void)//计算三角形的周长
{
    float s;
    s1=A.Distance1(B);
    s2=B.Distance1(C);
    s3=C.Distance1(A);
    s=s1+s2+s3;
    return s;
}
bool CTriangle::isIsoscelesTriangle()
{
    bool f=false;
    if(s1==s2||s2==s3||s3==s1)
        f=true;
    return f;
}
bool  CTriangle::isRightTriangle()
{
    bool f=false;
    if(s1*s1+s2*s2==s3*s3||s1*s1+s3*s3==s2*s2||s3*s3+s2*s2==s1*s1)
        f=true;
    return f;
}
float CTriangle::area(void)
{
    float s,q;
    s1=A.Distance1(B);
    s2=B.Distance1(C);
    s3=C.Distance1(A);
    q=(s1+s2+s3)/2;
    s=sqrt(q*(q-s1)*(q-s2)*(q-s3));
    return s;
}

void CPoint::input(double a,double b)
{
    x=a;
    y=b;
}
double CPoint::Distance1(CPoint p) const
{
    double s;
    s=sqrt((x-(p.x))*(x-(p.x))+(y-(p.y))*(y-(p.y)));
    return s;
}
void CTriangle::setTriangle(CPoint &X,CPoint &Y,CPoint &Z)
{
    X.input(0,0);
    A=X;
    B=Y;
    C=Z;

}
int main()
{
    CPoint s1,s2,s3;
    double a1,a2,a3,a4,a5,a6;
    cout<<"请输入第一个点的坐标"<<endl;
    cin>>a1>>a2;
    cout<<"请输入第二个点的坐标"<<endl;
    cin>>a3>>a4;
    cout<<"请输入第三个点的坐标"<<endl;
    cin>>a5>>a6;
    s1.input(a1,a2);
    s2.input(a3,a4);
    s3.input(a5,a6);
    CTriangle t1(s1,s2,s3);
    bool f1=false,f2=false;
    cout<<"三角形的周长是:"<<t1.perimeter()<<endl;
    cout<<"三角形的面积是:"<<t1.area()<<endl;
    f1=t1.isRightTriangle();
    if(f1==true)
    {
        cout<<"是直角三角形!"<<endl;
    }
    else
    {
         cout<<"不是直角三角形!"<<endl;
    }
    f2=t1.isIsoscelesTriangle();
    if(f2==true)
    {
        cout<<"是等腰三角形!"<<endl;
    }
    else
    {
        cout<<"不是等腰三角形!"<<endl;
    }

    return 0;
}


 

感悟

不断在进步!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值