/*
* Copyright (c) 2014, 烟台大学计算机学院
* All rights reserved.
* 作 者:沈远宏
* 完成日期:2014 年 4 月 07 日
* 版 本 号:v1.0
* 输入描述: 无
* 问题描述:设计平面坐标点类,计算两点之间距离、到原点距离、关于坐标轴和原点的对称点等。在设计中,由于求距离、求对称点等操作对原对象不能造成任何改变,所以,将这些函数设计为常成员函数是合适的,能够避免数据成员被无意更改。
* 程序输出:略
* 问题分析:略
* 算法设计:略
*/#include <iostream>
#include <cmath>
using namespace std;
class CPoint
{
private:
double x;//横坐标
double y;//纵坐标
public:
CPoint(double xx=0,double yy=0):x(xx),y(yy) {};
void Set_CPoint(double xx=0,double yy=0)
{
x=xx;
y=yy;
}
double Distance1(CPoint p)const;//两点之间的距离,(一点是当前点,另一点是参数p)
double Distance0()const;//到原点的距离
void SymmetricAxis(char style)const;//style取'x''y'和'0'分别表示x轴,y轴,原点对称。
void input();//以x,y形式输入坐标点
void output();//以(x,y)形式输出坐标点
};
double CPoint::Distance1(CPoint p)const
{
double distance_p;
distance_p=sqrt((CPoint::x-p.x)*(CPoint::x-p.x)+(CPoint::y-p.y)*(CPoint::y-p.y));
return distance_p;
}
double CPoint::Distance0()const
{
double distance_p;
distance_p=sqrt(CPoint::x*CPoint::x+CPoint::y*CPoint::y);
return distance_p;
}
void CPoint::SymmetricAxis(char style)const
{
CPoint xl;
switch(style)
{
case 'x':
xl.x=CPoint::x,xl.y=-CPoint::y;
break;
case 'y':
xl.x=-CPoint::x,xl.y=CPoint::y;
break;
case 'o':
xl.x=-CPoint::x,xl.y=-CPoint::y;
break;
}
cout<<"("<<xl.x<<","<<xl.y<<")"<<endl;
}
void CPoint::input()
{
double x1,y1;
char t;
cout<<"请输入点,以x,y的形式:\n";
cin>>x1>>t>>y1;
while(t!=',')
{
cout<<"error,请重新输入:";
cin>>x1>>t>>y1;
}
CPoint::Set_CPoint(x1,y1);
}
void CPoint::output()
{
cout<<"("<<CPoint::x<<","<<CPoint::y<<")\n";
}
int main()
{
CPoint a(3,4);
CPoint p;
char style;
cout<<"请准备好参数点\n";
p.input();
cout<<"两点之间的距离为:"<<a.Distance1(p)<<endl;
cout<<"该点到原点的距离为:"<<a.Distance0()<<endl;
cout<<"请选择对称方式(‘x’,'y','o')";
cin>>style;
while(style!='o'&&style!='x'&&style!='y')
{
cout<<"error,请重新输入!"<<endl;
cin>>style;
}
cout<<"该点关于"<<style<<"轴对称的点为";
a.SymmetricAxis(style);
return 0;
}
运行结果:
心得体会:
本想周末上传的,结果南校校区停电,没传,拖到了礼拜一。
最近不愿意去机房上机,老是觉得有种压迫感,所以总是想回宿舍自己做,
不知道最近怎么了,莫非是春困秋乏夏打盹?