/*
*程序的版权和版本声明部分:
*Copyright(c)2013,烟台大学计算机学院学生
*All rights reserved.
*文件名称:
*作者:尚振伟
*完成日期:2014年4月1日
*版本号:v0.1
*对任务及求解方法的描述部分:
*输入描述:无
*问题描述:设计平面坐标点类,计算两点之间距离、到原点距离、关于坐标轴和原点的对称点等。
*程序输入:
*程序输出:
*问题分析:
*算法设计:
*我的程序:
*/
#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; // 两点之间的距离(一点是当前点,另一点为参数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;
}
double CPoint::Distance1(CPoint p) const
{
double a,b,d,m;
a=p.x-x;
b=p.y-y;
m=a*a+b*b;
d=sqrt(m);
return d;
}
double CPoint::Distance0() const
{
double c;
c=sqrt(x*x+y*y);
return c;
}
CPoint CPoint::SymmetricAxis(char style) const
{
CPoint p;
switch(style)
{
case 'x':
p.x=x;
p.y=-y;
break;
case 'y':
p.x=-x;
p.y=y;
break;
case 'o':
p.x=-x;
p.y=-y;
}
return p;
}
void CPoint::input()
{
cout<<"请输入坐标:"<<endl;
cin>>x>>y;
}
void CPoint::output()
{
cout<<x<<","<<y<<endl;
}
int main()
{
CPoint t,k,l;
t.input();
cout<<"坐标为:";
t.output();
cout<<"与原点的距离为:";
cout<<t.Distance0()<<endl;
cout<<"关于X轴对称的坐标为:"<<endl;
k=t.SymmetricAxis('x');
k.output();
cout<<"关于Y轴对称的坐标为:"<<endl;
k=t.SymmetricAxis('y');
k.output();
cout<<"关于原点对称的坐标为:"<<endl;
k=t.SymmetricAxis('o');
k.output();
cout<<"求与另一点的距离:"<<endl;
l.input();
cout<<"此两点间的距离为:"<<endl;
cout<<t.Distance1(l)<<endl;
return 0;
}
结果展示: