第七周任务三

/* (程序头部注释开始)
* 程序的版权和版本声明部分
* Copyright (c) 2011, 烟台大学计算机学院学生 
* All rights reserved.
* 文件名称:                              
* 作    者:刘杨                              
* 完成日期:2012 年 4 月 3 日
* 版 本 号:          

* 对任务及求解方法的描述部分
* 输入描述: 
* 问题描述: 
* 程序输出: 
* 程序头部的注释结束
*/

#include <iostream> 
 
using namespace std;  

template<class numtype> 
  
class Complex     
{  
public:  
    Complex( ){numtype real=0;numtype imag=0;}       
    Complex(numtype r,numtype i){real=r;imag=i;}   
    Complex complex_add(const Complex<numtype> &c2);  
    Complex Complex_reduce(const Complex<numtype> &c2);  
    Complex Complex_multiplication(const Complex<numtype> &c2);  
    Complex Complex_division(const Complex<numtype> &c2);  
    void display( );     
private:  
numtype  real;   
numtype imag;   
}; 
 
template<class numtype>   
Complex<numtype> Complex<numtype>::complex_add(const Complex<numtype> &c2)  
{  
    Complex<numtype> c;  
    c.real=real+c2.real;  
    c.imag=imag+c2.imag;  
    return c;  
}  

template<class numtype>      
void Complex<numtype>::display( )     
{  
    cout<<"("<<real<<","<<imag<<"i)"<<endl;  
}  

template<class numtype>  
Complex<numtype> Complex<numtype>::Complex_reduce(const Complex<numtype> &c2)  
{  
   Complex<numtype> c;  
   c.real=real-c2.real;  
    c.imag=imag-c2.imag;  
    return c;  
}  

template<class numtype>  
Complex<numtype> Complex<numtype>::Complex_multiplication(const Complex<numtype> &c2)  
{  
    Complex<numtype> 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_division(const Complex<numtype> &c2)  
{  
    Complex<numtype> c;  
    c.real=(real*c2.real+imag*c2.imag)/(c2.real*c2.real+c2.imag*c2.imag);  
    c.imag=(imag*c2.real-real*c2.imag)/(c2.real*c2.real+c2.imag*c2.imag);  
    return c;  
}  

int main( )  
{   Complex<int> c1(-12,16),c2(5,-10),c3;    
    c3=c1.complex_add(c2);    
    cout<<"c1+c2=";   
    c3.display( );  
    c3=c1.Complex_reduce(c2);  
    cout<<"c1-c2=";  
    c3.display();  
    c3=c1.Complex_multiplication(c2);  
    cout<<"c1*c2=";  
    c3.display();  
    c3=c1.Complex_division(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_reduce(c5);  
    cout<<"c4-c5=";  
    c6.display();  
    c6=c4.Complex_multiplication(c5);  
    cout<<"c4*c5=";  
    c6.display();  
    c6=c4.Complex_division(c5);  
    cout<<"c4/c5=";  
    c6.display();  
    system("pause");  
    return 0;  
}  


运行结果:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值