/*
*Copyright (c)2015,烟台大学计算机与控制工程学院
*All rights reserved.
*文件名称:score.cpp
*作 者:惠睿
*完成日期:2015年4月5日
*版 本 号: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;
double Distance0() const;
CPoint SymmetricAxis(char style) const;
void input();
void output();
};
CPoint::CPoint(double xx,double yy)
{
x=xx;
y=yy;
}
double CPoint::Distance1(CPoint p) const
{
double dx,dy;
dx=p.x-x;
dy=p.y-y;
return sqrt(dx*dx+dy*dy);
}
double CPoint::Distance0() const
{
return sqrt(x*x+y*y);
}
CPoint CPoint::SymmetricAxis(char style) const
{
CPoint p(this->x,this->y);
switch(style)
{
case 'x':
p.y*=-1;
break;
case 'y':
p.x*=-1;
break;
case 'o':
{
p.x*=-1;
p.y*=-1;
break;
}
}
return p;
}
void CPoint::input()
{
char a;
cout<<"(格式: x,y):";
cin>>x>>a>>y;
if(a!=',')
cout<<"形式错误,请重新输入!"<<endl;
}
void CPoint::output()
{
cout<<"("<<x<<","<<y<<")"<<endl;
}
int main()
{
double distance;
CPoint p1,p2,p;
cout<<"请输入第一个点p1";
p1.input();
cout<<"请输入第二个点p2:";
p2.input();
distance=p1.Distance1(p2);
cout<<"p1与p2之间的距离为:"<<distance<<endl;
cout<<"p1与原点之间的距离为:"<<p1.Distance0()<<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;
}
运行结果:
学习心得:这个程序是费了好大劲做的,一直不怎么理解 CPoint p 是什么意思,现在差不多理解了吧!下面的程序就是加深理解的过程了。