6.3 设计平面坐标点类

原创 2012年03月28日 17:36:44

/* (程序头部注释开始)
* 程序的版权和版本声明部分
* Copyright (c) 2011, 烟台大学计算机学院学生
* All rights reserved.
* 文件名称:         第六周 任务三                    
* 作    者:            杨森                 
* 完成日期:     2012    年   3    月    27    日
* 版 本 号:     v1.0    

* 对任务及求解方法的描述部分
* 输入描述:
* 问题描述:
* 程序输出:
* 程序头部的注释结束

#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)   
    double Distance0() const;             // 到原点的距离   
    CPoint SymmetricAxis(SymmetricStyle style) const;        // 返回对称点   
    void input();        //以x,y 形式输入坐标点   
    void output();      //以(x,y) 形式输出坐标点   
};  
  
CPoint::CPoint(double xx, double yy):x(xx),y(yy){}  
  
int main()  
{  
    CPoint c1, c2;  
  
    c1.input();  
  
    c2.input();  
  
    c1.output();  
  
    c2.output();  
  
    cout << "两点间的距离是:" << c1.Distance(c2) << endl;  
  
    cout << "点到原点的距离是:" << c2.Distance0() << endl;  
  
    c1.SymmetricAxis(axisx);  
  
    c1.SymmetricAxis(axisy);  
  
    c1.SymmetricAxis(point);  
  
    system("pause");  
}  
  
CPoint CPoint::SymmetricAxis(SymmetricStyle style) const  
{  
    switch(style)  
    {  
    case(axisx):  
        {  
            cout << "点" << "(" << x << "," << y << ")"<< "关于X轴对称点是: (" << x << "," << - y << ")" << endl;  
            break;  
        }  
    case(axisy):  
        {  
            cout << "点" << "(" << x << "," << y << ")" << "关于Y轴对称点是: (" << - x << "," << y << ")" << endl;  
            break;  
        }  
    default:  
        {  
            cout << "点" << "(" << x << "," << y << ")"<< "关于原点对称点是: (" << - x << "," << - y << ")" << endl;  
            break;  
        }  
    }  
    return (x, y);  
}  
  
double CPoint::Distance(CPoint p) const  
{  
    return sqrt((p.x - x) * (p.x - x) + (p.y - y) * (p.y - y));  
}  
  
double CPoint::Distance0() const  
{  
    return sqrt(x * x + y * y);  
}  
  
  
void CPoint::input()  
{  
    char c;  
  
    cout << "请输入点坐标:(格式:x,y)" << endl;  
  
    do  
    {  
        cin >> x >> c >> y;  
  
        if(c == ',')  
        {  
            break;  
        }  
  
        cout << "格式不正确,请重新输入:" << endl;  
  
    }while(1);  
}  
  
void CPoint::output()  
{  
    cout << "点坐标(" << x << "," << y << ")" << endl;  
}  

小感: const 还需要深入理解和好好运用啊
版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

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

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

第6周-任务3-设计平面坐标点类

【题目】设计平面坐标点类,计算两点之间距离、到原点距离、关于坐标轴和原点的对称点等enum SymmetricStyle { axisx,axisy,point};//分别表示按x轴, y轴, 原点对...

第六周任务3(设计平面坐标点类)

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

任务三:设计平面坐标点类

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

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

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

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

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

6-3 平面坐标点类(欢迎高手指点评论)

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

第4周-项目1-体验常成员函数-平面坐标点类

问题及代码: /* *Copyright (c)2015,烟台大学计算机与控制工程学院 *All rights reserved. *文件名称:point.cpp *...

第六周实验报告(任务三)【平面坐标点类】

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

第六周任务3:平面坐标点类

/* (程序头部注释开始) * 程序的版权和版本声明部分 * Copyright (c) 2011, 烟台大学计算机学院学生 * All rights reserved. * 文件名称: ...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

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