第六周 RW 4

原创 2012年03月28日 18:13:22
/* (程序头部注释开始)
* 程序的版权和版本声明部分
* Copyright (c) 2011, 烟台大学计算机学院学生 
* All rights reserved.
* 文件名称:                              
* 作    者:   李兆庆                          
* 完成日期:   2012      年   3    月    27    日
* 版 本 号:          

* 对任务及求解方法的描述部分
* 输入描述:   
* 问题描述:   设计平面坐标点类,计算两点间的距离,到原点的距离以及关于x轴,y轴,原点对称的点.
* 程序输出: 
* 程序头部的注释结束
*/

#include < iostream >

#include < cmath >

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

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 形式输入坐标点

	void output ( ); //以(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 ;                                                          //三顶点

};

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

// 两点之间的距离(一点是当前点,另一点为参数p)

double CPoint :: Distance ( CPoint p ) const
   
{

	return sqrt ( ( x - p.x ) * ( x - p.x ) + ( y - p.y ) * ( y - p.y ) );

}

//以x,y 形式输入坐标点

void CPoint :: input ( )

{

	char ch ;

	while ( 1 )
	{
		cin >> x >> ch >> y;

		if ( ch != ',' )
		{

			cout << " 你输入的格式错误 " << endl;

		}

		else

		{

			break;

		}

	}

}

void CPoint::output ( )//以(x,y) 形式输出坐标点

{

	cout << x <<',' << y << endl;
	
}
void CTriangle::setTriangle(CPoint &X,CPoint &Y,CPoint &Z)  
{  
    A=X;  
    B=Y;  
    C=Z;
}

//计算三角形的周长

double CTriangle :: perimeter ( void )

{

	double a = A.Distance ( C ),

		b = B.Distance ( C ),

		c = A.Distance ( B );

	return  ( a + b + c );

}

//计算并返回三角形的面积

double CTriangle :: area ( void )

{
	double a =  A . Distance ( C ),

		b = B . Distance ( C ) ,

		c = A . Distance ( B ) ,

		s = ( a + b +  c ) / 2 ;

	return sqrt ( s * ( s - a ) * ( s - b ) * ( s - c ) );

}

 //是否为直角三角形

bool CTriangle :: isRightTriangle ( ) 

{
	double a = A . Distance ( C ),

		b = B . Distance ( C ) ,

		c = A . Distance ( B ) ;

	if ( ( abs ( a * a - b * b - c * c ) < 1e-6 ) || ( abs ( b * b - a * a - c * c ) < 1e-6 ) || ( abs ( c * c -b * b - a * a ) < 1e-6 ) )

	{
		return true;
	}
	else 
	{
		return false;
	}

}

//是否为等要三角形

bool CTriangle :: isIsoscelesTriangle ( ) 

{
		double a = A . Distance ( C ),

		b = B . Distance ( C ),

		c = A . Distance ( B );

		if ( ( abs ( a * a - b * b - c * c ) < 1e-6 ) || ( abs ( b * b - a * a - c * c ) < 1e-6 ) || ( abs ( c * c -b * b - a * a ) < 1e-6 ) )

		{
			return true;
		}
		else
		{
			return false;
		
		}

}

 
void main (void )

{

	CTriangle Tri1 ( CPoint ( 0 , 0 ) , CPoint ( 0 , 2 ) , CPoint ( 2 , 0 ) );

	cout << "该三角形的周长为:" << Tri1 . perimeter ( ) << " ,面积为:" << Tri1 . area ( ) << endl; 

	cout << "该三角形" << ( Tri1 . isRightTriangle ( ) ? "是" : "不是" ) << "直角三角形" << endl;

	cout << "该三角形" << ( Tri1 . isIsoscelesTriangle ( ) ?"是":"不是") << "等腰三角形" << endl;

	system ( " pause " );

}

      还是得看书啊,有些代码实现还是对我来说困难挺大的!多读,多写代码····

[4] rw_《CSAPP》2Ed 8 11-12 章 《APUE》15章·简

2016.08.31 - 09.07 《CSAPP》2Ed.12 章。 - Bryant·O’Hallaron / 著 - 龚奕利 雷应春 / 译 个人学习笔记。08.31第11 章 网络编程...

rw_《计算机是怎样跑起来的》4-11 章

2016.07.15 - 08.19 《计算机是怎样跑起来的》4-11 章。 - 矢泽久雄 / 著 - 胡屹 / 译 个人学习笔记。[知识的范围(编程)]4 程序像河水一样流淌着问题 & 重...

第六周实践项目4--数制转换

问题及代码: /* Copyright (c)2015,烟台大学计算机与控制工程学院 All rights reserved. 文件名称:第6周项目4--数...
  • TonyABu
  • TonyABu
  • 2015年10月12日 16:56
  • 378

第六周上机实践项目-项目4-静态成员应用

/* 问题及代码: *文件名称: *作者:刘涛 完成日期:2016.4.4 * *问题描述:设计含有静态数据成员和成员函数的time类。 *输入描述:无 程序输...

第六周任务(4)

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

第六周上机实践项目4——成员函数、友元函数和一般函数有区别

问题及代码 完成求点类中距离的任务。你需要实现求距离函数的三种版本:分别利用成员函数、友元函数和一般函数求两点间距离的函数,并设计main()函数完成测试。 /* * Copyright (...

第六周—项目4 - 数制转换

问题及代码: /* *Copyright(c)2015,烟台大学计算机与控制工程学院 *All right reserved. *文件名称:main.cpp *作者:程昂 *完成...
  • luguoca
  • luguoca
  • 2015年10月09日 08:53
  • 309

第六周 项目4-队列数组

链队的应用

第六周【项目4-静态时间类】

/* *Copyright (c)2016,烟台大学计算机与控制工程学院 *All rights reserved. *文件名称:main.cpp *作 者:张珩瑞 *完成日期:2016年4月6...

第六周实验报告(任务4)

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

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