/*
* 程序的版权和版本声明部分:
* Copyright (c) 2013.烟台大学计算机学院
* All rights reserved.
* 文件名称: 复数模板类
* 作 者:冯冬影
* 完成日期:2014 年 4月 11日
* 版 本 号:v1.0
* 对任务及求解方法的描述部分:
* 输入描述:
* 问题描述:
* 程序输出:
*/
#include<iostream>
using namespace std;
template<class T>//声明类模板T
class Complex
{
public:
Complex()
{
real=0;
imag=0;
}
Complex(T a,T b)
{
real=a;
imag=b;
}
Complex complex_add(Complex&);
Complex complex_dec(Complex&);
Complex complex_mul(Complex&);
Complex complex_div(Complex&);
void display();
private:
T real;
T imag;
};
template <class T>
Complex <T> Complex<T>::complex_add(Complex <T> &c1)
{
Complex <T> c;
c.real=real+c1.real;
c.imag=imag+c1.imag;
return c;
}
template <class T>
Complex <T> Complex<T>::complex_dec(Complex <T> &c1)
{
Complex <T> c;
c.real=real-c1.real;
c.imag=imag-c1.imag;
return c;
}
template <class T>
Complex <T> Complex<T>::complex_mul(Complex <T> &c1)
{
Complex <T> c;
c.real=real*c1.real+imag*c1.imag;
c.imag=real*c1.imag+imag*c1.real;
return c;
}
template <class T>
Complex <T> Complex<T>::complex_div(Complex <T> &c1)
{
Complex <T> c;
c.real=(real*c1.real-imag*c1.imag)/(c1.real*c1.real+c1.imag*c1.imag);
c.imag=(imag*c1.real-real*c1.imag)/(c1.real*c1.real+c1.imag*c1.imag);
return c;
}
template<class T>
void Complex<T>::display()
{
cout<<"("<<real<<","<<imag<<"i)"<<endl;
}
int main( )
{
Complex<int> c1(3,4),c2(5,-10),c3;
c3=c1.complex_add(c2);
cout<<"c1+c2=";
c3.display();
c3=c1.complex_dec(c2);
cout<<"c1-c2=";
c3.display();
c3=c1.complex_mul(c2);
cout<<"c1*c2=";
c3.display();
c3=c1.complex_div(c2);
cout<<"c1/c2=";
c3.display();
Complex<double> c4(3.1,4.4),c5(5.34,-10.21),c6;
c6=c4.complex_add(c5);
cout<<"c4+c5=";
c6.display();
c6=c4.complex_dec(c5);
cout<<"c4-c5=";
c6.display();
c6=c4.complex_mul(c5);
cout<<"c4*c5=";
c6.display();
c6=c4.complex_div(c5);
cout<<"c4/c5=";
c6.display();
return 0;
}
运行结果