平面坐标类

/* 
* 程序的版权和版本声明部分 
* Copyright (c)2012, 烟台大学计算机学院学生 
* All rightsreserved. 
* 文件名称: object.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);
	void Distance(CPoint p) const;   // 两点之间的距离(一点是当前点,另一点为参数p)
	void Distance0() const;          // 到原点的距离
	void 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;
}
//以x,y 形式输入坐标点
void CPoint::input()
{
	char n,s,t;
	cout<<"输入点的坐标,(如:(x,y)):";
	while(1)
	{
	cin>>n>>x>>s>>y>>t;
	if(n=='(' || t==')' || s==',')break;
	cout<<"格式错误,请重新输入!"<<endl;
	}
}
 //以(x,y) 形式输出坐标点
void CPoint::output()
{
	cout<<"("<<x<<","<<y<<")"<<endl;
}
// 两点之间的距离(一点是当前点,另一点为参数p)
void CPoint::Distance(CPoint p)const
{
	cout<<"两点间的距离为:"<<sqrt((x-p.x)*(x-p.x)+(y-p.y)*(y-p.y))<<endl;
}
// 到原点的距离
void CPoint::Distance0()const
{
	cout<<"到原点的距离是:"<<sqrt(x*x+y*y)<<endl;
}
//style取'x','y'和'o'分别表示按x轴, y轴, 原点对称
void CPoint::SymmetricAxis(char style)const
{
	switch(style)
	{
	case '0':
		cout<<"点1关于原点的对称点为:"<<"("<<-x<<","<<-y<<")"<<endl;
		break;
	case 'x':
		cout<<"点1关于x轴的对称点为:"<<"("<<x<<","<<-y<<")"<<endl;
		break;
	case 'y':
		cout<<"点1关于y轴的对称点为:"<<"("<<-x<<","<<y<<")"<<endl;
		break;
	default:
		cout<<"输入错误,请重新输入:"<<endl;
		break;
	}
}


int main()
{
	CPoint p1,p2;
	cout<<"点1,";
	p1.input();
	cout<<"点2,";
	p2.input();
	p1.Distance(p2);
	p1.Distance0();
	p1.SymmetricAxis('0');
	p1.SymmetricAxis('x');
	p1.SymmetricAxis('y');
	return 0;
}

平面坐标类_第1张图片

你可能感兴趣的:(平面坐标类)