第六周任务五

原创 2012年03月27日 21:19:48
* 程序的版权和版本声明部分 
* 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;
}



第六周任务四与五之

头文件: shengming.h class CPoint { private: double x; // 横坐标 double y; // 纵坐标 public: CPoi...

C++程序设计实验报告(四十七)---第六周任务五

/* (程序头部注释开始) * 程序的版权和版本声明部分 * Copyright (c) 2012, 烟台大学计算机学院学生 * All rights reserved. * 文件名称:计算...

第六周任务五(由点表示的三角形类用多个文件的方式实现)

将任务4的解决用一个项目多个文件的方式实现,其中两个类的声明放在一个.h文件中,每个类的成员函数分别放一个文件,main()函数用一个文件。体会这样安排的优点。 /* (程序头部注释开始) ...

第六周任务三设计平面坐标点类,计算两点之间距离、到原点距离、关于坐标轴和原点的对称点等

/* (程序头部注释开始) * 程序的版权和版本声明部分 * Copyright (c) 2011, 烟台大学计算机学院学生 * All rights reserved.* 文件名称: *...

第六周任务(4)

#include #include using namespace std; enum SymmetricStyle { axisx,axisy,point};//分别表示按x轴, y轴, 原点对...

第六周作业任务四

/* (程序头部注释开始) * 程序的版权和版本声明部分 * Copyright (c) 2011, 烟台大学计算机学院学生 * All rights reserved. *...

C++程序设计实验报告(四十五)---第六周任务三

/* (程序头部注释开始) * 程序的版权和版本声明部分 * Copyright (c) 2012, 烟台大学计算机学院学生 * All rights reserved. * 文件名称:计算...

第六周任务二按要求填缺少的代码

/* (程序头部注释开始) * 程序的版权和版本声明部分 * Copyright (c) 2011, 烟台大学计算机学院学生  * All rights reserved. * 文件名称:设计...

第六周实验报告 任务二

源程序: #include using namespace std; class A { private: int a; public: A() {a=0;} ...

C++第六周任务二程序填空按要求将缺少的代码填进去

/* (程序头部注释开始) * 程序的版权和版本声明部分 * Copyright (c) 2011, 烟台大学计算机学院学生 * All rights reserved. * 文件名称:程序...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:第六周任务五
举报原因:
原因补充:

(最多只允许输入30个字)