2013第六周上机任务【项目4 三角形类】

/* 
* Copyright (c) 2013, 烟台大学计算机学院                     
* All rights reserved.                     
* 文件名称:test.cpp                     
* 作者:樊露露                    
* 完成日期:2013 年 4 月 8 日                     
* 版本号:v1.0                   
*                     
* 输入描述:无                     
* 问题描述:                  
* 程序输出:
 * 问题分析:                    
* 算法设计:略                     
*/         
#include<iostream>
#include<Cmath>
using namespace std;

//点类
class CPoint  
{  
private:  
	double x;  // 横坐标   
	double y;  // 纵坐标   
public:  
	CPoint(double xx=0,double yy=0);  
	double distance(CPoint p) const;   // 两点之间的距离   
	void input();  //以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;//三个顶点
};

CPoint::CPoint(double xx,double yy){
	x=xx;
	y=yy;
}

void CPoint::input(){
	
	char ch;  
	cout<<"请输入坐标点(格式x,y ):";  
	while(1)  
	{  
		cin>>x>>ch>>y;  
		if (ch==',') break;  
		cout<<"输入的数据格式不符合规范,请重新输入\n";  
	}    
}

double CPoint::distance(CPoint p) const{
	return sqrt((p.x-x)*(p.x-x)+(p.y-y)*(p.y-y));
}

void CTriangle::setTriangle(CPoint &X,CPoint &Y,CPoint &Z){
	cout<<"输入三角形的三点:";
	X.input();A=X;
	Y.input();B=Y;
	Z.input();C=Z;
}
float CTriangle::perimeter(void){
	float a,b,c;
	a=B.distance(C);
	b=A.distance(C);
	c=A.distance(B);
	return a+b+c;
}
float 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);
  double max=a;
  if(b>max) max=b;
  if(c>max) max=c;
  if(((max==a)&&(abs(a*a-b*b-c*c)<1e-7))||((max==b)&&(abs(b*b-a*a-c*c)<1e-7))||((max==c)&&(abs(c*c-b*b-a*a)<1e-7)))
    return true;
  else
    return false;
}
bool CTriangle::isIsoscelesTriangle() //是否为等腰三角形
{
  double a=B.distance(C),b=C.distance(A),c=A.distance(B);
  if((abs(a-b)<1e-7)||(abs(b-c)<1e-7)||(abs(c-a)<1e-7))
    return true;
  else
    return false;
}

int main()  
{  
    CPoint X,Y,Z;  
	CTriangle Tri1(X,Y,Z);//定义三角形类的一个实例(对象)
	Tri1.setTriangle( X, Y, Z);
	cout<<"该三角形的周长为:"<<Tri1.perimeter()<<",面积为:"<<Tri1.area()<<endl<<endl;  
    cout<<"该三角形"<<(Tri1.isRightTriangle()?"是":"不是")<<"直角三角形"<<endl;  
    cout<<"该三角形"<<(Tri1.isIsoscelesTriangle()?"是":"不是")<<"等腰三角形"<<endl;  
    return 0;  
}  

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值