一.问题描述

数据的间距问题(函数模板) 类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

五.代码实现 

#include<iostream>
#include<cmath>
using namespace std;

class Point {
private:
    double x;
    double y;
    double z;
public:
    Point(double a, double b, double c) :x(a), y(b), z(c) {};    //构造函数初始化
    friend double operator-(Point, Point);             //重载运算符(作为友元可以访问数据成员)
};

template <class T>
double dist(T a, T b) {                  //函数模板以兼容不同种类的数据
    return abs(a - b);
}

double operator-(Point P1, Point P2) {
    return sqrt(pow(P1.x - P2.x, 2) + pow(P1.y - P2.y, 2) + pow(P1.z - P2.z, 2));   //对于Point类对象“-”运算符的重载
}

int main() {
    int i, j;
    float p, q;
    double x1, y1, z1, x2, y2, z2;
    int flag;
    while (1) {
        cin >> flag;
        if (flag == 0) {
            break;               //标志符flag 遇到0退出循环。
        }
        if (flag == 1) {
            cin >> i >> j;
            cout << dist(i, j) << endl;
        }
        else if (flag == 2) {
            cin >> p >> q;
            cout << dist(p, q) << endl;
        }
        else {
            cin >> x1 >> y1 >> z1 >> x2 >> y2 >> z2;
            Point P1(x1, y1, z1), P2(x2, y2, z2);
            cout << dist(P1, P2) << endl;
        }
    }
    return 0;
}

 

posted on 2023-05-23 22:52  leapss  阅读(19)  评论(0)    收藏  举报