第六周任务四

* 程序的版权和版本声明部分 
* Copyright (c) 2011, 烟台大学计算机学院学生
* All rights reserved. 
* 文件名称:                             
* 作    者:董宝文                        
* 完成日期:       2012  年   3    月   27     日 
* 版 本 号:       01.05.04   对任务及求解方法的描述部分 
* 输入描述:<span> </span> 
* 问题描述: 设计一个学生类包括学号和成绩,建立一个对象数组,内放5个学生的数据 
* 程序输出: 输出第1、3、5个学生的信息,并输出成绩最高学生的学号 
* 程序头部的注释结束 
#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;   // 两点之间的距离(一点是当前点,另一点为参数p)
	void input();  //以x,y 形式输入坐标点
};
CPoint::CPoint(double xx,double yy)
{
	x = xx;
	y = yy;
}
	
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; //三顶点
};
void CTriangle::setTriangle(CPoint &X,CPoint &Y,CPoint &Z)
{
	A = X;
	B = Y;
	C = Z;
}

double CTriangle::perimeter(void)
{
	double d,d1,d2,d3;

	d1 = A.Distance(B);
	d2 = B.Distance(C);
	d3 = C.Distance(A);

	d = d1 + d2 + d3;

	return d;
}
double CTriangle::area(void)
{
	double area,p, d,d1,d2,d3;

	d1 = A.Distance(B);
	d2 = B.Distance(C);
	d3 = C.Distance(A);

    d = d1 + d2 + d3;
	p = 0.5 * d;
	area = sqrt(p * (p - d1) * (p - d2) * (p - d3));

	return area;
}
bool CTriangle::isIsoscelesTriangle()
{
	bool p = false;
	double d1,d2,d3;

	d1 = A.Distance(B);
	d2 = B.Distance(C);
	d3 = C.Distance(A);

	if(d1 == d2 || d2 == d3 || d1 == d3)
		p = true;

	return p;
}

bool CTriangle::isRightTriangle()
{
	bool p = false;
	double d1,d2,d3;

	d1 = A.Distance(B);
	d2 = B.Distance(C);
	d3 = C.Distance(A);
 
	if((abs( d1 * d1 -d2*d2-d3*d3)<1e-7)||(abs(d1*d1-d3*d3-d2*d2)<1e-7)||(abs(d2*d2-d3*d3-d1*d1)<1e-7))
		p = true;

	return p;
}

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 CPoint::input()
{
	cout << "请输入x和y的值:" << endl;

	cin >> x >> y;
}
int main()
{
	CPoint A,B,C;


	A.input();
	B.input();
	C.input();
	CTriangle Tri(A,B,C);
	cout << "该三角形的周长为:" << Tri.perimeter() << ",面积为:" << Tri.area() << endl << endl;  
    cout << "该三角形" << (Tri.isRightTriangle()?"是":"不是") << "直角三角形" << endl;  
    cout << "该三角形" << (Tri.isIsoscelesTriangle()?"是":"不是") << "等腰三角形" << endl; 
	
	system("pause");

	return 0;
}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值