项目三(平面坐标点类)

/*    

*程序的版权和版本声明部分          

* Copyright (c)2013, 烟台大学计算机学院学生       

* All rightsreserved.         

* 文件名称:Cpoint .cpp       

* 作    者:  田凤        

*完成日期:2013年4月9日      

* 版本号: v1.0                 

* 输入描述: 输入点的坐标 

* 问题描述:对点的计算  

* 输出:输出距离以及对称点

*代码:

#include<iostream>
#include<Cmath>
#include <stdlib.h>
using namespace std;
class Cpoint
{
private:
 double x; //横坐标
 double y; //纵坐标
public:
 Cpoint(double xx=0,double yy=0);
 void input(); //以x,y形式输入坐标点
 void output(); //以(x,y)形式输出坐标点
 double Distance0()const;//到原点的距离
 double Distance(Cpoint p)const;//两点之间的距离(一点为当前点,一点为参数p)
 Cpoint SymmetricAxis(char style)const;//style取'x','y'和'O'分别表示按x轴,y轴,原点对称
};
Cpoint::Cpoint(double xx,double yy)
{
 x=xx;
 y=yy;
};
void Cpoint::input()  //以x,y形式输入坐标点
{
 char c;
 cout<<"(格式为x,y)"<<" ";
 while(1)
 {
  cin>>x>>c>>y;
  if (c==',')
  {
   break;
  }
  cout<<"输入坐标点的格式不正确,请重新输入:"<<endl;
  input();
 }
}
void Cpoint::output()  //以(x,y)形式输出坐标点
{
 cout<<"("<<x<<","<<y<<")"<<endl;
}
double Cpoint::Distance0()const  //到原点的距离
{
 double d1;
 d1=sqrt(x*x+y*y);
 return d1;
}
double Cpoint::Distance(Cpoint p)const  //两点之间的距离(一点为当前点,一点为参数p)
{
 double d2;
    d2=sqrt((p.x-x)*(p.x-x)+(p.y-y)*(p.y-y));
    return d2;
}
Cpoint Cpoint::SymmetricAxis(char style)const  //style取'x','y'和'O'分别表示按x轴,y轴,原点对称
{
 Cpoint p(this->x,this->y);//用复制构造函数时,写作p(*this)
 switch(style)
 {
 case 'x':
  p.y=-y;
  break;
 case 'y':
  p.x=-x;
  break;
 case 'o':
  p.x=-x;
  p.y=-y;
 }
    return p;
}
int main()
{
    double d;
 Cpoint p1,p2,p;
 cout<<"输入第一个点p1:";
 p1.input();
 cout<<endl;
 cout<<"输入第二个点p2:";
 p2.input();
 cout<<endl;
 d=p1.Distance0();
 cout<<"第一个点到原点的距离为:"<<d<<endl;
 cout<<endl;
 d=p2.Distance0();
 cout<<"第二个点到原点的距离为:"<<d<<endl;
 cout<<endl;
 d=p1.Distance0();
 cout<<"两点之间的距离为:"<<d<<endl;
 cout<<endl;
 p=p1.SymmetricAxis('x');
 cout<<"p1关于x轴的对称点为:";
 p.output();
 p=p1.SymmetricAxis('y');
 cout<<"p1关于y轴的对称点为:";
 p.output();
 p=p1.SymmetricAxis('o');
 cout<<"p2关于原点的对称点为:";
 p.output();
 cout<<endl;
 p=p2.SymmetricAxis('x');
 cout<<"p2关于x轴的对称点为:";
 p.output();
 p=p2.SymmetricAxis('y');
 cout<<"p2关于y轴的对称点为:";
 p.output();
 p=p2.SymmetricAxis('o');
 cout<<"p2关于原点的对称点为:";
 p.output();
 return 0;
}

 

 

*运行结果:

                     项目三(平面坐标点类)_第1张图片

*心得体会:求对称点时用复制构造函数不太明白~~

你可能感兴趣的:(项目三(平面坐标点类))