第七周任务(二)

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

* 程序的版权和版本声明部分
* Copyright (c) 2012, 烟台大学计算机学院
* All rights reserved.
* 文件名称: 求点类中距离

* 作 者:     刘洋
* 完成日期: 2012 年 4 月 2 日
* 版 本 号: 1.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 p) const;       // 两点之间的距离(一点是当前点,另一点为参数p)  
	friend double Distance2(CPoint &,CPoint &);  //友元函数实现求两点距离
	void input();        //以x,y 形式输入坐标点   
	void output();      //以(x,y) 形式输出坐标点  
	double getx(){return x;}      //用于得到x
	double gety(){return y;}   //用于得到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");  
}