-->
当前位置:首页 > 题库 > 正文内容

7-3 2017final函数模板 (20 分)

Luz4年前 (2021-03-08)题库1644
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;
}


发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。