/* (程序头部注释开始)
* 程序的版权和版本声明部分
* Copyright (c) 2011, 烟台大学计算机学院学生
* All rights reserved.* 文件名称: 000
* 作 者: 杨继宇
* 完成日期: 2012年04 月04 日
* 版 本 号: 0000
* 对任务及求解方法的描述部分
* 输入描述:
* 问题描述:
* 程序输出:
* 程序头部的注释结束
*/
#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){} double distance1(const CPoint &) ; // 两点之间的距离(一点是当前点,另一点为参数p) friend double distance2(const CPoint &,const CPoint &); void input(); //以x,y 形式输入坐标点 void output(); //以(x,y) 形式输出坐标点 double getx(){return x;} double gety(){return y;} }; double distance3( CPoint &, CPoint &); double CPoint::distance1(const CPoint &p) { return sqrt((p.x - x) * (p.x - x) + (p.y - y) * (p.y - y)); } double distance2(const CPoint &p1,const CPoint &p2) { return sqrt((p1.x - p2.x) * (p1.x - p2.x) + (p1.y - p2.y) * (p1.y - p2.y)); } double distance3( CPoint &p1,CPoint &p2) { return sqrt((p1.getx() - p2.getx()) * (p1.getx() - p2.getx()) + (p1.gety() - p2.gety()) * (p1.gety() - p2.gety())); } void CPoint::input() { cout << "请输入点坐标:(格式:x,y)" << endl; cin >> x >> y; } void CPoint::output() { cout << "(" << x << "," << y << ")" << endl; } void main() { CPoint c1, c2; c1.input(); c2.input(); c1.output(); c2.output(); cout<<c1.distance1(c2)<<endl; cout<<distance2(c1,c2)<<endl; cout<<distance3(c1,c2)<<endl; system("pause"); }