第七周项目四复数模板类

/*
02.* Copyright (c) 2013, 烟台大学计算机学院
03.* All rights reserved.
04.* 文件名称:test.cpp
05.* 作者:荆世琛
06.* 完成日期:2013 年 4 月 20 日
07.* 版本号:v1.0
08.*
09.* 输入描述:无
10.* 问题描述:
11.* 程序输出:
12.* 问题分析:
13.* 算法设计:略
14.*/

#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 &);
	Complex complex_minus(Complex &);
	Complex complex_multiply(Complex &);
	Complex complex_divide(Complex &);
	void display();
private:
	numtype real;
	numtype imag;
};

template<class numtype>
Complex<numtype> Complex<numtype>::complex_add(Complex<numtype> &c)
{
	Complex<numtype> c1;
	c1.real=real+c.real;
	c1.imag=imag+c.imag;
    return c1;
}

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

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

//复数相乘:(a+bi)(c+di)=(ac-bd)+(bc+ad)i
template<class numtype>
Complex<numtype> Complex<numtype>::complex_multiply(Complex<numtype> &c)
{
   Complex<numtype> c1;
   c1.real=real*c.real-imag*c.imag;
   c1.imag=imag*c.real+real*c.imag;
   return c1;
}

//复数相除:(a+bi)/(c+di)=(ac+bd)/(c^2+d^2) +(bc-ad)/(c^2+d^2)i
template<class numtype>
Complex<numtype> Complex<numtype>::complex_divide(Complex<numtype> &c)
{
	  Complex<numtype> c1;
      numtype d=c.real*c.real+c.imag*c.imag;
	  c1.real=(real*c.real+imag*c.imag)/d;
      c1.imag=(imag*c.real-real*c.imag)/d;
      return c1;
}

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( );

	c6=c4.complex_minus(c5);
	cout<<"c4-c5=";
	c6.display( );

	c6=c4.complex_multiply(c5);
	cout<<"c4*c5=";
	c6.display( );

	c6=c4.complex_divide(c5);
	cout<<"c4/c5=";
	c6.display( );
	return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值