首页 > 其他分享 >daka :p

daka :p

时间:2023-05-05 19:23:53浏览次数:29  
标签:daka int double 元素 Complex type 输入

复数类Complex有两个数据成员:a和b, 分别代表复数的实部和虚部,并有若干构造函数和一个重载-(减号,用于计算两个复数的距离)的成员函数。 要求设计一个函数模板

template < class T >

double dist(T a, T b)

对int,float,Complex或者其他类型的数据,返回两个数据的间距。

以上类名和函数模板的形式,均须按照题目要求,不得修改

输入格式:

每一行为一个操作,每行的第一个数字为元素类型,1为整型元素,2为浮点型元素,3为Complex类型,若为整型元素,接着输入两个整型数据,若为浮点型元素,接着输入两个浮点型数据,若为Complex型元素,输入两个Complex型数据(a1 b1 a2 b2),输入0时标志输入结束。

输出格式:

对每个输入,每行输出一个间距值。

输入样例:

1 2 5

3 2 4 5 9

2 2.2 9.9

0

 

输出样例:

3

5.83095

7.7

#include<bits/stdc++.h>
using namespace std;

class Complex 
{
public:
    double a, b;
    Complex(double a = 0, double b = 0) : a(a), b(b) {}
    double operator-(const Complex& c) const {
        return sqrt((a - c.a) * (a - c.a) + (b - c.b) * (b - c.b));
    }
};

template <class T>
double dist(T a, T b) {
    return abs(a - b);
}

int main() {
    int type;
    while (cin >> type && type != 0) {
        if (type == 1) {
            int a, b;
            cin >> a >> b;
            cout << dist(a, b) << endl;
        } else if (type == 2) {
            double a, b;
            cin >> a >> b;
            cout << dist(a, b) << endl;
        } else if (type == 3) {
            double a1, b1, a2, b2;
            cin >> a1 >> b1 >> a2 >> b2;
            Complex c1(a1, b1), c2(a2, b2);
            cout << dist(c1, c2) << endl;
        }
    }
    return 0;
}

 

标签:daka,int,double,元素,Complex,type,输入
From: https://www.cnblogs.com/kongxiangzeng/p/17375143.html

相关文章

  • daka :p
     #include<bits/stdc++.h>usingnamespacestd;voidprint(ints[]);intjudge(intc[]);intj=0;intmain(){ intsweet[10]={10,2,8,22,16,4,10,6,14,20}; inti,t[10],l; printf("child12345678910\n"); printf......