第7周实验报告3

* (程序头部注释开始)  
* 程序的版权和版本声明部分  
  
* Copyright (c) 2011, 烟台大学计算机学院学生  
  
* All rights reserved.  
  
* 文件名称:实现了一个复数类  
  
* 作 者:朱亚楠  
  
 * 完成日期: 2011年 4月 4日  
  
*版 本 号:  
  
 * 对任务及求解方法的描述部分  
  
 *问题描述:通过模板类的技术手段,设计Complex,使实部和虚部的类型为定义对象时用的实际类型。  
  
  
 * 程序输出:  
  
* 程序头部的注释结束*/  
#include <iostream>    
using namespace std;    
template<class numtype>//定义类模板    
class Complex       
{    
public:    
    Complex( ){real=0;imag=0;}         
    Complex(numtype r,numtype i){rreal=r;iimag=i;}     
    Complex complex_add(Complex &c2); //加法    
    Complex complex_sub(Complex &c2);//减法    
    Complex complex_div(Complex &c2);//除法    
    Complex complex_mult(Complex &c2);//乘法    
    void display( );       
private:    
    numtype real;     
    numtype imag;     
};    
    
//定义加法    
template<class numtype>    
Complex<numtype> Complex<numtype>::complex_add(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_sub(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_div(Complex<numtype> &c2)    
{    
    Complex<numtype> 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>    
Complex<numtype> Complex<numtype>::complex_mult(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>    
void Complex<numtype>::display( )       
{    
    cout<<"("<<real<<","<<imag<<"i)"<<endl;    
}    
int main( )    
{   Complex<int> c1(3,4),c2(5,-10),c3,c7;      
    c3=c1.complex_add(c2);    
    cout<<"c1+c2=";     
    c3.display( );     
    c7=c1.complex_sub(c2);    
    cout<<"c1-c2=";    
    c7.display();    
    Complex<double> c4(3.1,4.4),c5(5.34,-10.21),c6,c8;      
    c6=c4.complex_div(c5);      
    cout<<"c4/c5=";     
    c6.display( );     
    c8=c4.complex_mult(c5);    
    cout<<"c4*c5=";    
    c8.display( );    
    system("pause");    
    return 0;    
}

上机感想:几乎这些程序都要多多少少的寻求帮助,唉,自己都有些自卑啊。。。不过团队合作也很重要啊~~~嘿嘿

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值