六周任务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;  
}  
 

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

第十六周任务3

/* (程序头部注释开始) * 程序的版权和版本声明部分 * Copyright (c) 2012, 烟台大学计算机学院学生 * All rights reserved. * 文件名称:字典 * 作...
  • yuchenziyou
  • yuchenziyou
  • 2012年06月14日 12:40
  • 3136

十六周任务3

* 程序的版权和版本声明部分 * Copyright (c) 2011, 烟台大学计算机学院学生 * All rights r...
  • wangmingxing123
  • wangmingxing123
  • 2012年06月06日 12:24
  • 600

六周三次课

1、  awk命令:   -F   #指定分隔符 OFS   #print的时候指定的分隔符 NR    #表示行 NF    #表示段 awk –F ‘:’ ‘{print $1}’ t...
  • csdn_chenc
  • csdn_chenc
  • 2018年01月17日 17:50
  • 12

第十六周上机任务3

/* (程序头部注释开始) * 程序的版权和版本声明部分 * Copyright (c) 2011, 烟台大学计算机学院学生 * All rights reserved. * 文件名称:re...
  • dqybzs
  • dqybzs
  • 2012年06月04日 19:25
  • 465

十六周任务3;电子词典

#include #include #include #include using namespace std; class Word { public: Word() ...
  • yangjianhe1210
  • yangjianhe1210
  • 2012年06月06日 12:41
  • 1383

六周一次课

1、  正则__grep:   正则就是一串有规律的字符串 掌握好正则对于编写shell脚本有很大帮助 各种编程语言中都有正则,原理是一样的   grep [-cinvABC] ‘word...
  • csdn_chenc
  • csdn_chenc
  • 2018年01月15日 14:48
  • 15

六周第三次课 2017.11.22 awk

9.6/9.7 awk awk支持分段 指定分隔符为:,列出第一段。(打印所有的段就把1改成0) 列出文件所有内容。(不用F指定分隔符,默认是以空白为分隔符) 指定分隔符为:,列出第1...
  • wtyufdssyh
  • wtyufdssyh
  • 2017年11月22日 22:47
  • 33

hiho一下 第十六周 RMQ-ST算法

RMQ (Range Minimum/Maximum Query)问题:对于长度为N的数列a,若干次查询,每次给出R和L,a[L——R]的最小(大)值,也就是说,RMQ问题是指求区间最值的问题。 此...
  • ZzebraA
  • ZzebraA
  • 2016年04月08日 21:02
  • 206

《第十六周实验报告任务3——电子词典》

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

第十六周项目一任务3—字符串

/* * 程序的版权和版本声明部分 * Copyright (c)2012, 烟台大学计算机学院学生 * All rightsreserved. * 文件名称: array.cpp ...
  • gintama2012
  • gintama2012
  • 2012年12月11日 20:04
  • 366
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:六周任务3
举报原因:
原因补充:

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