/* (程序头部注释开始)
* 程序的版权和版本声明部分
* Copyright (c) 2012, 烟台大学计算机学院学生
* All rights reserved.
* 文件名称: 求点类中距离
* 作 者: 于晨
* 完成日期: 2012 年 04月 01 日
* 版 本 号: 1.045
* 对任务及求解方法的描述部分
* 输入描述:两个坐标点
* 问题描述: 如何用友元访问,比较一般函数之间的区别
* 程序输出: 点间距
* 程序头部的注释结束
*/
- #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(CPoint p) const;
- friend double Distance2(CPoint &,CPoint &);
- void input();
- void output();
- double getx(){return x;}
- double gety(){return y;}
- };
-
- double Distance3(CPoint &,CPoint &);
-
- double CPoint::Distance1(CPoint p) const
- {
- return sqrt((p.x - x) * (p.x - x) + (p.y - y) * (p.y - y));
- }
-
- void CPoint::input()
- {
- char c;
-
- cout << "请输入点坐标:(格式:x,y)" << endl;
-
- do
- {
- cin >> x >> c >> y;
-
- if(c == ',')
- {
- break;
- }
-
- cout << "格式不正确,请重新输入:" << endl;
-
- }while(1);
- }
-
- void CPoint::output()
- {
- cout << "点坐标(" << x << "," << y << ")" << endl;
- }
-
- double Distance2(CPoint &p1,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()));
- }
-
- int 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");
- }