第七周上机任务项目4-复数模板类

01./*      
02.* 程序的版权和版本声明部分      
03.* Copyright (c)2013, 烟台大学计算机学院学生      
04.* All rightsreserved.      
05.* 文件名称:complx.cpp                                 
06.* 作    者:赵冠哲                                  
07.* 完成日期:2013年4月12日      
08.* 版本号: v1.0            
09.* 输入描述:      
10.* 问题描述:    
11.*/
#include<iostream>
using namespace std;
template<class numtype>
class Complex
{
	public:
		Complex(){real=0;imag=0;}
		Complex(numtype r, numtype i){real=r;imag= i;}
	    Complex complex_add(Complex &c2); 
		Complex complex_cut(Complex &c2);  
		Complex complex_mul(Complex &c2);  
		Complex complex_div(Complex &c2);  
		void display();
	private:
		numtype real;
		numtype imag;
};
template <class numtype>  
Complex<numtype> Complex<numtype>::complex_add(Complex &c2)
{
	Complex c;
	c.real=real+c2.real;
	c.imag=imag+c2.imag;
	return c;
}
template <class numtype>
Complex<numtype> Complex<numtype>::complex_cut(Complex &c2)
{
	Complex c;
	c.real=real-c2.real;
	c.imag=imag-c2.imag;
	return c;
}
template <class numtype>
Complex<numtype> Complex<numtype>::complex_mul(Complex &c2)
{
	Complex c;
	 c.real = real*c2.real-imag*c2.imag;  
	 c.imag = real*c2.imag+imag*c2.real;  
	return c;
}
template <class numtype>
Complex<numtype> Complex<numtype>::complex_div(Complex &c2)
{
	Complex c;
   c.real=(real*c2.real+imag*c2.imag)/(c2.real*c2.real+c2.imag*c2.imag);  
   c.imag=(-real*c2.imag+imag*c2.real)/(c2.real*c2.real+c2.imag*c2.imag);  
	return c;
}
template <class numtype>
void Complex<numtype>::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( );  
	Complex<double> c4(3.1,4.4),c5(5.34,-10.21),c6;  
	c6=c4.complex_add(c5);  
	cout<<"c4+c5="; 
	c6.display( ); 
	//下面测试减法、乘法和除法
    Complex<int> c7(3, 3), c8(6, -1), c9;   
    c9 = c7.complex_cut(c8);    
    cout << "c7-c8=";   
    c9.display( );  
    Complex<int> c10(3, 4), c11(5,5), c12;   
    c12=c10.complex_mul(c11);    
   cout << "c10*c11=";   
    c12.display( ); 
	   Complex<double> c13(5,3), c14(4,6), c15;   
    c15=c13.complex_mul(c14);    
   cout << "c13/c14=";   
    c15.display( ); 
	return 0;
}


运行结果:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值