/* * Copyright (c) 2013, 煙台大學電腦學院 * All rights reserved. * 檔案名稱:test.cpp * 作者:樊露露 * 完成日期:2013 年 4 月 15 日 * 版本號碼: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){} double distance1(CPoint &); friend double distance2(CPoint &, CPoint &) ;double getX(){return x;}double getY(){return y;}};double distance3(CPoint &,CPoint &) ;//定義一般函數double CPoint::distance1(CPoint &p) //成員函數的定義{double dx=(x-p.x), dy=y-p.y; return sqrt(dx*dx+dy*dy);}double distance2(CPoint &p1,CPoint &p2) //友元函數的定義{double dx=(p1.x-p2.x), dy=p1.y-p2.y; return sqrt(dx*dx+dy*dy);}double distance3(CPoint &p1,CPoint &p2) //一般函數的定義{double dx=(p1.getX()-p2.getX()), dy=p1.getY()-p2.getY(); return sqrt(dx*dx+dy*dy);}int main(){CPoint p1(10,13), p2(-5,6);cout<<"1. "<<p1.distance1(p2)<<endl;cout<<"2. "<<distance2(p1,p2)<<endl;cout<<"3. "<<distance3(p1,p2)<<endl;system("pause");return 0;}