* 程序的版权和版本声明部分
* Copyright (c) 2011, 烟台大学计算机学院学生
* All rights reserved.
* 文件名称:
* 作 者:董宝文
* 完成日期: 2012 年 3 月 27 日
* 版 本 号: 01.05.04 对任务及求解方法的描述部分
* 输入描述:<span> </span>
* 问题描述: 设计一个学生类包括学号和成绩,建立一个对象数组,内放5个学生的数据
* 程序输出: 输出第1、3、5个学生的信息,并输出成绩最高学生的学号
* 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;
double a,b;
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 形式输入坐标点
};
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; //三顶点
};
#include "he.h"
CPoint::CPoint(double xx,double yy)
{
x = xx;
y = yy;
}
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;
}