*
* 程序的版权和版本声明部分
* 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;
}
第六周 项目三 点 类问题
最新推荐文章于 2022-05-11 11:35:17 发布