六周任务3

原创 2012年03月26日 20:41:40
#include <iostream>
#include <cmath>

using namespace std;

enum SymmetricStyle { axisx , axisy , point };

class CPoint
{
private :
 double x ;
 double y ;

public :
 CPoint( double xx = 0 , double yy = 0 );//构造函数声明

 double Distance ( CPoint p ) const ;//求两点距离函数声明

 double Distance0() const ;//求点到原点距离函数声明

 CPoint SymmetricAxis ( SymmetricStyle ) const ;//求对称点

    void input() ;//按x , y的形式输入点

 void output() ;//按(x,y)输出点的值

};

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

void  CPoint::input()
{
 cout << "按 x , y 的形式输入坐标点" << endl ;
  cin >> x >> y ;
}

void  CPoint::output()
{
cout<< "点的坐标为:" <<"("<< x <<","<< y <<")"<< endl ;
}

double  CPoint::Distance0() const
{
 double H ;
  
 H = sqrt ( x * x + y * y ) ;
 return H;
}

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

int main()
{
 CPoint cp1 , cp2 ;

 cp2.input() ;
 cp1.input() ;
 cp1.output() ;

 cout << "点到原点的距离为:" << cp1.Distance0()<< endl ; 

 cout << "两点之间的距离为:" << cp1.Distance ( cp2 )<< endl ;

 cp1.SymmetricAxis( axisx );
 cout<< endl ;
 cp1.SymmetricAxis( axisy );
 cout<< endl ;
 cp1.SymmetricAxis( point );

 system ("pause") ;

 return  0 ;
}

CPoint CPoint::SymmetricAxis(SymmetricStyle style)  const  // 返回对称点   
{  
    switch(style)  //利用switch语句选择
    {  
    case axisx:  
        cout<<"点("<<x<<","<<y<<")"<<"关于y轴对称的点为:";   
        cout<<"("<<-x<<","<<y<<")";  
        break;  
    case axisy:  
        cout<<"点("<<x<<","<<y<<")"<<"关于x轴对称的点为:";  
        cout<<"("<<x<<","<<-y<<")";  
       break;  
    case point:  
        cout<<"点("<<x<<","<<y<<")"<<"关于原点对称的点为:";  
        cout<<"("<<-x<<","<<-y<<")";  
        break;  
    }  
    return 0;  
}  
 

   运行结果: 
 
感受:这里的选择结构有点困难,用时过长了,加油。。。。

版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

六周任务5

//任务五 main.cpp #include #include #include "class.h" using namespace std; int main(...

六周任务4.1

#include #include using namespace std; class CPoint { private : double x ; double y ;...

六周任务三

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

六周任务2.2

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

六周任务四

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

六周 BX1.2改错

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

六周 BX1.1

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

C++走向远洋——30(六周,项目一1.0)

*/ * Copyright (c) 2016,烟台大学计算机与控制工程学院 * All rights reserved. * 文件名:fenshu.cpp * 作者:常轩 * 微信公众号:...
  • vcx08
  • vcx08
  • 2016-04-06 21:04
  • 448

HMP3自制任务

  • 2014-10-14 18:15
  • 2.63MB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

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