第七周项目1-点类-友元函数
2016-04-09 19:49
435 查看
问题及代码:
/*
*Copyright (c) 2016,烟台大学计算机学院
*All rights reserved.
*文件名称:zwj.cpp
*作 者:张伟晶
*完成日期:2016年4月9日
*版 本 号: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 getx(){return x;}
double gety(){return y;}
friend double line(CPoint &p1,CPoint &p2); //友元函数的声明
};
/*
class Line
{
public:
Line(CPoint xp1,CPoint xp2);
Line (Line &l);
double getlen(){return len;}
private:
CPoint p1,p2;
double len;
};
*/
double line(CPoint &p1,CPoint &p2)
{
double x=p1.x-p2.x;
double y=p1.y-p2.y;
return sqrt(x*x+y*y);
}
int main()
{
CPoint p1(1,1),p2(4,6.2);
// Line line(p1,p2);
cout<<"p1为:("<<p1.getx()<<","<<p1.gety()<<")"<<endl;
cout<<"p2为:("<<p2.getx()<<","<<p2.gety()<<")"<<endl;
cout<<"两点间距离为:"<<line(p1,p2)<<endl;
return 0;
}
运行结果:
知识点总结:
友元函数的定义与使用。
学习心得:
友元函数是指某些虽然不是类成员却能够访问类的所有成员的函数。
/*
*Copyright (c) 2016,烟台大学计算机学院
*All rights reserved.
*文件名称:zwj.cpp
*作 者:张伟晶
*完成日期:2016年4月9日
*版 本 号: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 getx(){return x;}
double gety(){return y;}
friend double line(CPoint &p1,CPoint &p2); //友元函数的声明
};
/*
class Line
{
public:
Line(CPoint xp1,CPoint xp2);
Line (Line &l);
double getlen(){return len;}
private:
CPoint p1,p2;
double len;
};
*/
double line(CPoint &p1,CPoint &p2)
{
double x=p1.x-p2.x;
double y=p1.y-p2.y;
return sqrt(x*x+y*y);
}
int main()
{
CPoint p1(1,1),p2(4,6.2);
// Line line(p1,p2);
cout<<"p1为:("<<p1.getx()<<","<<p1.gety()<<")"<<endl;
cout<<"p2为:("<<p2.getx()<<","<<p2.gety()<<")"<<endl;
cout<<"两点间距离为:"<<line(p1,p2)<<endl;
return 0;
}
运行结果:
知识点总结:
友元函数的定义与使用。
学习心得:
友元函数是指某些虽然不是类成员却能够访问类的所有成员的函数。
相关文章推荐
- Java中equals和==的区别
- text detection method
- 软件工程结对作业02(原创版)
- script 的运行方式差异 (source, sh script, ./script)
- HDU 1978 How many ways 记忆化dfs+dp
- leetcode---Path Sum
- 一些JS事件
- 可拖拽GridView代码解析
- 2010年山东省第一届ACM解SDUT2151-2160 set,floyd变形
- 汉诺塔递归算法
- Whu oj 1609 - Han Move
- 软件工程结对作业02(借鉴版)
- JavaScript编写人机对战五子棋(七)
- mysql.bat
- 栈面试题
- 第七周项目1-点类-成员函数
- Linux下硬链接和软链接
- 如何在博客园发博客时插入优酷视频
- Java-Eclipse编辑窗口不见了
- 嵌入式linux常用shell指令