第六周—3.平面坐标类

/* 
* 程序的版权和版本声明部分 
* Copyright (c)2012, 烟台大学计算机学院学生 
* All rightsreserved. 
* 文件名称: fun.cpp 
* 作 者:谷志恒
* 完成日期:2013 年4月6日 
* 版本号: 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 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;
}  
// 求两点之间的距离   
double CPoint::Distance(CPoint p) const
{
	return sqrt((x-p.x)*(x-p.x)+(y-p.y)*(y-p.y));
} 
// 求点到原点的距离     
double CPoint::Distance0()const
{
	return sqrt(x*x+y*y);
}
// 求对称点, style取'x','y'和'o'分别表示按x轴, y轴, 原点对称   
CPoint CPoint::SymmetricAxis(char style)const
{
	CPoint p(this->x,this->y);//用复制构造函数时,写作p(*this)   
	switch(style)
	{
	case 'x':
		p.y=-y;
		break;
	case 'y':
		p.x=-x;
		break;
	case '0':
		p.x=-x;
		p.y=-y;
		break;
	}
	return p;
}
// 输入坐标点 
void CPoint::input()
{
	char ch; 
	cout<<"以(x,y)的形式输入:";
	while(1)
  {
    cin>>x>>ch>>y;
    if (ch==',') break;
    cout<<"输入的数据格式不符合规范,请重新输入\n";
  }
}
// 输出坐标点 
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.Distance(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('0');
	cout<<"p1关于原点轴对称的点为:";
	p.output();
	return 0;
}


运行程序:第六周—3.平面坐标类_第1张图片

心得体会:用复制构造函数那里不大明白!!!

你可能感兴趣的:(第六周—3.平面坐标类)