第六周 项目六-复数模板-和差积商

 /*

 *Copyright (c) 2015,烟台大学计算机学院

 *All rights reserved.

 *文件名称:distance.cpp

 *作者:刘天恩

 *完成时间:2015年4月17号

 *版本号:v1.0

 *问题描述:阅读教材例10.1。该例实现了一个复数类,但是美中不足的是,复数类的实部和虚部都固定只能是double型的。
      可以通过模板类的技术手段,设计Complex,使实部和虚部的类型为定义对象时指定的实际类型。
    (1)要求类成员函数在类外定义。
    (2)在此基础上,再实现减法、乘法和除法

 *输入描述:无

 *程序输出:输出两个复数的和差积商

 */



#include <iostream>

using namespace std;
template<class T>
class Complex
{
public:
    Complex()
    {
        x=0;
        y=0;
    }
    Complex(T a,T b)
    {
        x=a;
        y=b;
    }
    Complex complex_add(Complex &); //复数相加
    Complex complex_minus(Complex &);  //复数相减
    Complex complex_mul(Complex &);   //复数相乘
    Complex complex_div(Complex &);   //复数相除
    void display();
private:
    T x;
    T y;
};

//复数加法
template<class T>
Complex <T> Complex<T>::complex_add(Complex<T> &p)
{
    Complex<T> C;
    C.x=x+p.x;
    C.y=y+p.y;
    return C;
}

//复数减法
template<class T>
Complex <T> Complex<T>::complex_minus(Complex<T> &p)
{
    Complex<T> C;
    C.x=x-p.x;
    C.y=y-p.y;
    return C;
}


//复数乘法
template<class T>
Complex <T> Complex<T>::complex_mul(Complex<T> &p)
{
    Complex<T> C;
    C.x=x*p.x-y*p.y;
    C.y=y*p.x+x*p.y;
    return C;
}



//复数除法
template<class T>
Complex <T> Complex<T>::complex_div(Complex<T> &p)
{
    Complex<T> C;
    C.x=(x*p.x+y*p.y)/(p.x*p.x+p.y*p.y);
    C.y=(y*p.x-x*p.y)/(p.x*p.x+p.y*p.y);
    return C;
}
template<class T>
void Complex<T>::display()
{
    cout<<"("<<x<<","<<y<<")i"<<endl;
}



int main( )
{
    Complex<int> c1(3,4),c2(5,-10),c3;   //实部和虚部是int型
    c3=c1.complex_add(c2);
    cout<<"c1+c2=";
    c3.display( );
    Complex<double> c4(3.1,4.4),c5(5.34,-10.21),c6; //实部和虚部是double型
    c6=c4.complex_add(c5);
    cout<<"c4+c5=";
    c6.display( );

    //下面测试减法、乘法和除法
    Complex<int> c7(3,3),c8(33,33),c9;
    c9=c7.complex_minus(c8);
    cout<<"c7-c8=";
    c9.display();
    Complex<double> c10(3.3,3.4),c11(33.03,33.83),c12;
    c12=c10.complex_minus(c11);
    cout<<"c10-c11=";
    c12.display();


    Complex<int> q1(7,3),q2(22,33),q3;
    q3=q1.complex_mul(q2);
    cout<<"q1*q2=";
    q3.display();
    Complex<double> q4(37.2,3.6),q5(25.36,56.32),q6;
    q6=q4.complex_mul(q5);
    cout<<"q4*q5=";
    q6.display();


    Complex<int> q7(3,5),q8(7,8),q9;
    q9=q7.complex_mul(q8);
    cout<<"q7/q8=";
    q9.display();
    Complex<double> q10(3.5,3.3),q11(33.56,33.33),q12;
    q12=q10.complex_mul(q11);
    cout<<"q10/q11=";
    q12.display();


    return 0;
}



运行结果:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值