第六周 项目三 点 类问题

*      
* 程序的版权和版本声明部分      
* Copyright (c)2013, 烟台大学计算机学院学生      
* All rightsreserved.      
* 文件名称: object.cpp      
* 作    者: 袁静      
* 完成日期:2013年4月17日      
* 版本号: v1.0      
* 输入描述:由键盘输入 点的座标    
* 问题描述:    
         点与点之间的距离,点关于x轴,y轴,原点的对称点  
  
#include <iostream>
#include <cmath>
using namespace std;
class Cpoint
{
public:
    Cpoint(double xx=0,double yy=0);
    double Distance(Cpoint p) const;
    double Distance0() const;
    void input();
    void  output();
    Cpoint symmetericAxis(char style ) const;
public:
    double x;
    double y;

};
void Cpoint::input ()
{
    char ch;
    while (1)
    {
        cin>>x>>ch>>y;
        if(ch==',')
            break;
        else
        cout<<"格式输入错误,请从新输入:"<<endl;
    }
}
Cpoint::Cpoint(double xx,double yy)
{
    x=xx;
    y=yy;
}
void Cpoint::output()
{
    cout<<"("<<x<<","<<y<<")"<<endl;
}
double Cpoint::Distance(Cpoint p)  const
{
    return sqrt((p.x-x)*(p.x-x)+(p.y-y)*(p.y-y));
}
double Cpoint::Distance0() const
{
    return sqrt(x*x+y*y);

}
Cpoint Cpoint::symmetericAxis(char style) const
{
    Cpoint p(this->x,this->y);
    switch(style)
    {
    case'x':
        p.y=-y;
        break;
    case'y':
        p.x=-x;
        break;
    case'0':
        p.y=-y;
        p.x=-x;
        break;

    }
    return p;

}
int main()
{
    Cpoint  p1,p2,p;
    cout<<"请输入第一个点的座标:"<<endl;
    p1.input();
    cout<<"请输入第二个点的座标:"<<endl;
    p2.input();
    cout<<"两点之间的距离为:"<<p1.Distance(p2)<<endl;
    cout<<"第一个点与原点两点的距离为:"<<p1.Distance0()<<endl;
    cout<<"第一个点关于x的对称点为:"<<endl;
    p=p1.symmetericAxis('x');
    p.output();
    cout<<"第一个点关于y的对称点为:"<<endl;
    p=p1.symmetericAxis('y');
    p.output();
    cout<<"第一个点关于原点的对称点为:"<<endl;
    p=p1.symmetericAxis('0');
    p.output();

      return 0;
}

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章