项目1-体验常指针函数

来源:互联网 发布:php 扩展开发 编辑:程序博客网 时间:2024/05/16 06:59

/*

 *Copyright (c) 2015,烟台大学计算机学院

 *All rights reserved.

 *文件名称:.cpp

 *作者:孙旭明

 *完成时间:2015年4月8号

 *版本号:v1.0

*问题描述:设计平面坐标点类,计算两点之间距离、到原点距离、关于坐标轴和原点的对称点等。在设计中,由于求距离、求对称点等操作对原对象不能造成任何改变,所以,将这些函数设计为常成员函数是合适的,能够避免数据成员被无意更改。
*结果输出:一系列相应的结果。

 */

#include <iostream>
#include "Cmath"
using namespace std;
class CPoint
{
private:
    double x;  // 横坐标
    double y;  // 纵坐标
public:
    CPoint(double xx=0,double yy=0);
    double Distance1(CPoint p) const; //两点之间的距离(一点是当前点——想到this了吗?,另一点为p)
    double Distance0() const;          // 到原点(0,0)的距离
    CPoint SymmetricAxis(char style) const;//style取'x','y'和'o'分别表示按x轴, y轴, 原点对称
    void input();  //以x,y 形式输入坐标点
    void output(); //以(x,y) 形式输出坐标点
};
CPoint::CPoint(double xx,double yy)
{
    x=xx;
    y=yy;
}
void CPoint::input()// 输入坐标点
{
    char ch;
    cout<<"请输入坐标点(格式x,y ):";
    while (1)
    {
        cin>>x>>ch>>y;
        if (ch==',')
            break;
        cout<<"输入的坐标格式不正确,请重新输入."<<endl;


    }
}
void CPoint::output()// 输出坐标点
{
    cout<<"("<<x<<", "<<y<<")"<<endl;
}
double CPoint::Distance1(CPoint p) const// 求两点之间的距离
{
    double d;
    d=sqrt((p.x-x)*(p.x-x)+(p.y-y)*(p.y-y));
    return d;
}
double CPoint::Distance0() const// 求点到原点的距离
{
    double d;
    d=sqrt(x*x+y*y);
    return d;
}
CPoint CPoint::SymmetricAxis(char style) const// 求对称点, style取'x','y'和'o'分别表示按x轴, y轴, 原点对称
{
    CPoint p(this->x,this->y);//用复制构造函数时,写作p(*this)
    switch(style)
    {
    case 'x':
        p.y=-y;
        break;
    case 'y':
        p.x=-x;
        break;
    case 'o':
        p.x=-x;
        p.y=-y;
    }
    return p;
}
int main()
{
    double distance;
    CPoint p1,p2,p;
    cout<<"第1个点p1,";
    p1.input();
    cout<<"第2个点p2,";
    p2.input();
    distance=p1.Distance1(p2);
    cout<<"两点的距离为:"<<distance<<endl;
    distance=p1.Distance0();
    cout<<"p1到原点的距离为:"<<distance<<endl;
    p=p1.SymmetricAxis('x');
    cout<<"p1关于x轴的对称点为:";
    p.output();
    p=p1.SymmetricAxis('y');
    cout<<"p1关于y轴的对称点为:";
    p.output();
    p=p1.SymmetricAxis('o');
    cout<<"p1关于原点的对称点为:";
    p.output();
    return 0;
return 0;
}


 

0 0