第七周任务(二)
来源:互联网 发布:mysql exists 代替 in 编辑:程序博客网 时间:2024/05/21 10:02
* 程序的版权和版本声明部分
* 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;} //用于得到xdouble 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"); }
- 第七周任务(二)
- 第七周 任务二
- 第七周任务二
- 第七周 任务二
- 第七周任务二
- 第七周任务二
- 第七周任务二
- 第七周任务二
- 第七周任务二
- 第七周任务二
- 第七周任务二
- 第七周任务二
- C++程序设计实验报告(四十九)---第七周任务二
- 《第七周实验报告任务二》
- 第七周实验报告任务二
- 第七周任务二 友元函数
- 第七周实验报告 任务二
- 第七周上机任务项目二
- 第七周任务1
- 第七周任务二(利用成员函数、友元函数和一般函数,实现三个版本的求两点间距离的函数)
- 第七周任务1含有静态数据成员和成员函数的Time类
- 第七周 任务三
- Linux/Unix中的基本系统数据类型
- 第七周任务(二)
- 将数组划分为两个元素和最接近的子数组
- 第七周作业3
- 第7周实验报告2
- POJ 3259 Wormholes (bellman_ford)
- 第七周任务(三)
- 第七周实验报告1
- flex meun 使用
- Process Resources