c++实现复数类

主要是练习用运算符重载实现复数的一些基本运算,包括:

复数加法(重载的运算符:+、+=、前置++、后置++);

复数减法(重载的运算符:-、-=、前置--、后置--);

复数乘法(重载的运算符:*、*=、);

复数除法(重载的运算符:/、/=、);

代码如下:

#include<iostream>
using namespace std;
class Complex
{
public:
 Complex(float real = 1, float imag = 1):_real(real), _imag(imag){}//构造函数
 Complex(const Complex& complex);//拷贝构造函数
 ~Complex(){};//析构函数
 Complex& operator=(const Complex& complex);//赋值操作符重载
 
 bool operator==(const Complex& complex);
 bool operator!=(const Complex& complex);
 Complex operator+(const Complex& complex);
 Complex& operator++();//前置++
 Complex operator++(int);//后置++
 Complex& operator+=(const Complex& complex);
 Complex operator-(const Complex& complex);
 Complex& operator-=(const Complex& complex);
 Complex& operator--();//前置--
 Complex operator--(int);//后置--
 Complex operator*(const Complex& complex);
 Complex& operator*=(const Complex& complex);
 Complex operator/(const Complex& complex);
 Complex& operator/=(const Complex& complex);
 friend ostream& operator<<(ostream& output, const Complex& complex);//输出操作符重载
private:
 float _real;
 float _imag;
};

 

各函数的实现:

Complex::Complex(const Complex& complex)//拷贝构造函数
{
 _real = complex._real;
 _imag = complex._imag;
}
 
Complex& Complex::operator=(const Complex& complex)//赋值操作符重载
{
 cout << "赋值操作符重载" << endl;
 if (this != &complex)
 {
  _real = complex._real;
  _imag = complex._imag;
 }
 return *this;
}
 
ostream& operator<<(ostream& output, const Complex& complex)//输出操作符重载
{
  output << "(" << complex._real;
 if (complex._imag >= 0)
 {
  output << "+";
 }
 output << complex._imag << "i)";
  return output;
}

bool Complex::operator==(const Complex& complex)
{
 return (_real == complex._real) && (_imag == complex._imag);
}

bool Complex::operator!=(const Complex& complex)
{
 return !(*this==complex);
}
 
Complex Complex::operator+(const Complex& complex)
{
 Complex c(*this);
 c._real +=complex._real;
 c._imag +=complex._imag;
 return c;
}
 
Complex& Complex::operator++()
{
 ++_real;
 return *this;
}
 
Complex Complex::operator++(int)
{
 Complex c;
 c._real=_real++;
 return c; 
}
 
Complex& Complex::operator+=(const Complex& complex)
{
 _real += complex._real;
 _imag += complex._imag;
 return *this;
}
 
Complex Complex::operator-(const Complex& complex)
{
 return Complex(_real - complex._real, _imag - complex._imag);
}
 
Complex& Complex::operator-=(const Complex& complex)
{
 _real -= complex._real;
 _imag -= complex._imag;
 return *this;
}
 
Complex& Complex::operator--()
{
 --_real;
 return *this;
}
 
Complex Complex::operator--(int)
{
 Complex c;
 c._real=_real--;
 return c;
}
 
Complex Complex::operator*(const Complex& complex)
{
 Complex c;
 c._real = _real*complex._real - _imag*complex._imag;
 c._imag = _real*complex._imag + _imag*complex._real;
 return c;
}
 
Complex& Complex::operator*=(const Complex& complex)
{
 float real = _real;
 _real = _real*complex._real - _imag*complex._imag;
 _imag = _imag*complex._real + real*complex._imag;
 return *this;
}
 
Complex Complex::operator/(const Complex& complex)
{
 return Complex((_real*complex._real + _imag*complex._imag) / 
                   (complex._real*complex._real + complex._imag*complex._imag),
       (_imag*complex._real - _real*complex._imag)/
       (complex._real*complex._real + complex._imag*complex._imag));
 /*Complex c;
 c._real = (_real*complex._real + _imag*complex._imag)*1.0 /
  (complex._real*complex._real + complex._imag*complex._imag);
 c._imag = (_imag*complex._real - _real*complex._imag)*1.0 /
  (complex._real*complex._real + complex._imag*complex._imag);
 return c;*/
}
 
Complex& Complex::operator/=(const Complex& complex)
{
 float real = _real;
 _real = (_real*complex._real + _imag*complex._imag)/
 (complex._real*complex._real + complex._imag*complex._imag);
 _imag = (_imag*complex._real - real*complex._imag) /
 (complex._real*complex._real + complex._imag*complex._imag);
 return *this;
}

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值