/*
*Copyright (c) 2015,烟台大学计算机学院
*All rights reserved.
*文件名称:distance.cpp
*作者:刘天恩
*完成时间:2015年4月17号
*版本号:v1.0
*问题描述:阅读教材例10.1。该例实现了一个复数类,但是美中不足的是,复数类的实部和虚部都固定只能是double型的。
可以通过模板类的技术手段,设计Complex,使实部和虚部的类型为定义对象时指定的实际类型。
(1)要求类成员函数在类外定义。
(2)在此基础上,再实现减法、乘法和除法
*输入描述:无
*程序输出:输出两个复数的和差积商
*/
#include <iostream>
using namespace std;
template<class T>
class Complex
{
public:
Complex()
{
x=0;
y=0;
}
Complex(T a,T b)
{
x=a;
y=b;
}
Complex complex_add(Complex &); //复数相加
Complex complex_minus(Complex &); //复数相减
Complex complex_mul(Complex &); //复数相乘
Complex complex_div(Complex &); //复数相除
void display();
private:
T x;
T y;
};
//复数加法
template<class T>
Complex <T> Complex<T>::complex_add(Complex<T> &p)
{
Complex<T> C;
C.x=x+p.x;
C.y=y+p.y;
return C;
}
//复数减法
template<class T>
Complex <T> Complex<T>::complex_minus(Complex<T> &p)
{
Complex<T> C;
C.x=x-p.x;
C.y=y-p.y;
return C;
}
//复数乘法
template<class T>
Complex <T> Complex<T>::complex_mul(Complex<T> &p)
{
Complex<T> C;
C.x=x*p.x-y*p.y;
C.y=y*p.x+x*p.y;
return C;
}
//复数除法
template<class T>
Complex <T> Complex<T>::complex_div(Complex<T> &p)
{
Complex<T> C;
C.x=(x*p.x+y*p.y)/(p.x*p.x+p.y*p.y);
C.y=(y*p.x-x*p.y)/(p.x*p.x+p.y*p.y);
return C;
}
template<class T>
void Complex<T>::display()
{
cout<<"("<<x<<","<<y<<")i"<<endl;
}
int main( )
{
Complex<int> c1(3,4),c2(5,-10),c3; //实部和虚部是int型
c3=c1.complex_add(c2);
cout<<"c1+c2=";
c3.display( );
Complex<double> c4(3.1,4.4),c5(5.34,-10.21),c6; //实部和虚部是double型
c6=c4.complex_add(c5);
cout<<"c4+c5=";
c6.display( );
//下面测试减法、乘法和除法
Complex<int> c7(3,3),c8(33,33),c9;
c9=c7.complex_minus(c8);
cout<<"c7-c8=";
c9.display();
Complex<double> c10(3.3,3.4),c11(33.03,33.83),c12;
c12=c10.complex_minus(c11);
cout<<"c10-c11=";
c12.display();
Complex<int> q1(7,3),q2(22,33),q3;
q3=q1.complex_mul(q2);
cout<<"q1*q2=";
q3.display();
Complex<double> q4(37.2,3.6),q5(25.36,56.32),q6;
q6=q4.complex_mul(q5);
cout<<"q4*q5=";
q6.display();
Complex<int> q7(3,5),q8(7,8),q9;
q9=q7.complex_mul(q8);
cout<<"q7/q8=";
q9.display();
Complex<double> q10(3.5,3.3),q11(33.56,33.33),q12;
q12=q10.complex_mul(q11);
cout<<"q10/q11=";
q12.display();
return 0;
}
运行结果: