/*
* Copyright (c) 2011, 烟台大学计算机学院
* All rights reserved.
* 作 者:杨蕾
* 完成日期:2013 年 4 月 10 日
* 版 本 号:v1.0
* 输入描述:
* 问题描述:
* 程序输出:
* 问题分析:
* 算法设计:略
*/
#include <iostream>
#include <cmath>
using namespace std;
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(char style)const;//style 取'x','y'和'o'分别表示按x 轴, y 轴, 原点对称
void input(); //以x,y 形式输入坐标点
void output(); //以(x,y) 形式输出坐标点
};
CPoint::CPoint(double xx,double yy)
{
x=xx;
y=yy;
}
void CPoint::input()
{
int a,b;
char s;
cout<<"请输入坐标"<<endl;
cin>>a>>s>>b;
if(s==','){
x=a;y=b;
}else{
cout<<"格式错误"<<endl;
input();
}
}
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));
}
int main()
{
CPoint p1,p2;
p1.input();
p2.input();
cout<<"p1,p2两点间的距离为:"<<p1.Distance(p2)<<endl;
cout<<"p1到原点的距离为:"<<p1.Distance0()<<endl;
return 0;
}
运行结果:
本文介绍了一个简单的CPoint类的设计与实现,该类用于表示二维坐标系中的点,并提供了计算两点间距离及到原点距离的方法。通过用户输入坐标,演示了如何使用这个类进行距离计算。
3482

被折叠的 条评论
为什么被折叠?



