/*
* 程序的版权和版本声明部分
* Copyright (c)2013, 烟台大学计算机学院学生
* All rightsreserved.
* 文件名称:score.cpp
* 作 者: 赵 洋
* 完成日期: 2013 年 04 月 5 日
* 版本号: v1.0
* 输入描述:点的坐标
* 问题描述:计算两点间的距离,点关于想,x轴,y轴,原点的对称点
* 输出:距离或点的坐标
*/
#include<iostream>
#include<cmath>
using namespace std;
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(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()
{
cout<<"请输入坐标:";
cin>>x>>y;
}
double CPoint::Distance(CPoint p) const
{
double d;
d=sqrt((p.x-x)*(p.x-x)+(p.y-y)*(p.y-y));
cout<<"两点间的距离为:"<<d<<endl;
return 0;
}
double CPoint::Distance0()const
{
double d;
d=sqrt(x*x+y*y);
cout<<"到原点的距离为:"<<d<<endl;
return 0;
}
CPoint CPoint::SymmetricAxis(char style )const
{
double x1,y1;
if(style=='x')
{
x1=-x;
y1=y;
}
if(style=='y')
{
x1=x;
y1=-y;
}
if(style=='o')
{
x1=-x;
y1=-y;
}
cout<<"关于"<<style<<"对称的点为:"<<x1<<" "<<y1<<endl;
return 0;
}
void CPoint::output()
{cout<<x<<" "<<y<<endl;}
int main()
{
CPoint t1;
t1.input();
t1.Distance0();
CPoint t2;
CPoint t3;
CPoint *p=&t2;
t2.input();
t3.input();
t3.Distance(* p);
t1.output();
t1.SymmetricAxis('x');
t2.output();
t2.SymmetricAxis('y');
t3.output();
t3.SymmetricAxis('o');
return 0;
}
运行结果: