源程序:
/*(文件注释头部开始)
*程序的版权和版本声明部分
*Copyright (c) 2011,烟台大学计算机学院学生
*All rights reserved.
*文件名称:平面坐标点类
*作 者:114-3张宗佳
*完成日期:2012年3月27号
*版本号:vc.3
* 对任务及求解方法的描述部分
* 输入描术:输入坐标点
* 问题描述:计算两点之间距离、到原点距离、关于坐标轴和原点的对称点等
* 程序输出:输出两点之间距离、到原点距离、关于坐标轴和原点的对称点等
* 程序头部的注释结束
*/
#include<iostream>
#include<cmath>
using namespace std;
enum SymmetricStyle { axisx,axisy,point};//分别表示按x轴, y轴, 原点对称
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(SymmetricStyle style) const; // 返回对称点
void input(); //以x,y 形式输入坐标点
void output(); //以(x,y) 形式输出坐标点
};
CPoint::CPoint(double xx,double yy):x(xx),y(yy){}
// 两点之间的距离(一点是当前点,另一点为参数p)
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));
}
// 返回对称点
CPoint CPoint::SymmetricAxis(SymmetricStyle style) const
{
CPoint p(x,y);
switch(style)
{
case axisx:
p.y = -y;
break;
case axisy:
p.x = -x;
break;
case point:
p.x = -x;
p.y = -y;
break;
}
return p;
}
//以x,y 形式输入坐标点
void CPoint::input()
{
char c;
cout << "格式:(x,y):" ;
cin >> x >> c >> y;
while(1)
{
if(c != ',')
{
cout << "格式出错请重输!" << endl;
}
else break;
}
return ;
}
//以(x,y) 形式输出坐标点
void CPoint::output()
{
cout << "(" << x << "," << y << ")" << endl;
}
void main()
{
CPoint p1,p2,p;
cout << "输入第一个点p1:" ;
p1.input();
cout << "输入第二个点p2:";
p2.input();
cout << "这两点之间的距离是:" << p1.Distance(p2) << endl;
cout << "p1,p2到原点的距离分别是:" ;
cout << p1.Distance0() << '\t' << p2.Distance0() << endl;
p = p1.SymmetricAxis(axisx);
cout << "p1关于x轴的对称点是:" ;
p.output();
p = p1.SymmetricAxis(axisy);
cout << "p1关于y轴的对称点是:" ;
p.output();
p = p1.SymmetricAxis(point);
cout << "p1关于原点的对称点是:" ;
p.output();
system("pause");
}
实验结果:
经验积累:
1.在这个任务中,运用到了在成员函数中用对象作参数,来计算两点之间的距离
2.用到了枚举类型,在成员函数中先定义一个对象,用switch语句做出对称点,再返回这个对象