7-3 2017final函数模板 (20 分)
数据的间距问题(函数模板) 类point有三个数据成员:x、y和z, 分别代表x坐标、y坐标和z坐标,并有若干构造函数和一个重载-(减号,计算两点距离)的成员函数。 要求设计一个函数模板,
template < class T> double dist(T a, T b)
对int,float,point或者其他类型的数据,返回间距。
输入格式:
每一行为一个操作,每行的第一个数字为元素类型,1为整型元素,2为浮点型元素,3为point类型,若为整型元素,接着输入两个整型数据,若为浮点型元素,接着输入两个浮点型数据,若为point型元素,输入两个point型数据(x1 y1 z1 x2 y2 z2),输入0时标志输入结束。
输出格式:
对每个输入,每行输出一个间距值。
输入样例:
1 2 5
3 2 4 7 5 9 7
2 2.2 9.9
0
输出样例:
3
5.83095
7.7
作者
east
单位
福州大学
代码长度限制
16 KB
时间限制
400 ms
内存限制
64 MB
#include<iostream> #include<math.h> using namespace std; template < class T> double dist(T a, T b) { double c = 0; c = a - b; return fabs(c); } class Point { private: double x; double y; double z; public: Point(double a = 0, double b = 0, double c = 0) { x = a; y = b; z = c; } double operator -(Point p1) { double a=0,b=0,c = 0,d=0; a = x - p1.x; b = y - p1.y; c = z - p1.z; d = a * a + b * b + c * c; return sqrt(d); } }; int main() { int ch = 0; while (cin >> ch) { if (ch == 0) break; else if (ch == 1) { int a = 0, b = 0; double c = 0; cin >> a >> b; c = dist(a, b); cout << c << endl; } else if (ch == 2) { float a = 0, b = 0; double c = 0; cin >> a >> b; c = dist(a, b); cout << c << endl; } else if (ch == 3) { double x1 = 0, y1 = 0, z1 = 0, x2 = 0, y2 = 0, z2 = 0; double c = 0; cin >> x1 >> y1 >> z1 >> x2 >> y2 >> z2; Point p1(x1, y1, z1), p2(x2, y2, z2); c = dist(p1, p2); cout << c << endl; } } return 0; }