第七周任务二

时间:2022-08-05 08:03:43

/* (程序头部注释开始)

* 程序的版权和版本声明部分

* 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");  
      
}