c++ complex 实现

1.complex.h


#ifndef COMPLEX_H
#define COMPLEX_H
class Complex
{
public:
	Complex(double r = 0,double i = 0):m_re(r),m_im(i){}
	Complex& operator+= (const Complex& rhs);  
	Complex& operator-= (const Complex& rhs);
	//基于练习的目的 将一个写为成员函数
	Complex operator* ( const Complex& rhs);  

	double real()const { return this->m_re; }
	double imag()const { return this->m_im; }

private:
	friend Complex& __doapl(Complex* lhs, const Complex& rhs);
	friend Complex& __doami(Complex* lhs, const Complex& rhs);
	friend Complex& __doaml(Complex* lhs, const Complex& rhs);

	double m_re;
	double m_im;
};
//基于练习的目的 将一个 写为非成员函数
Complex& operator*= (Complex &lhs,const Complex& rhs); 
Complex operator+ (const Complex& lhs, const Complex& rhs);
Complex operator- (const Complex& lhs, const Complex& rhs);




#endif // !COMPLEX_H

2.complex.cpp

#include <iostream>
#include "complex.h"

std::ostream& operator<< (std::ostream& os, const Complex& rhs)
{
	return os << "(" << rhs.real() << "," << rhs.imag() << ")";
}

Complex& __doapl(Complex* lhs,const Complex& rhs)
{
	lhs->m_re += rhs.m_re;
	lhs->m_im += rhs.m_im;
	return *lhs;
}

Complex& __doami(Complex* lhs, const Complex& rhs)
{
	lhs->m_re -= rhs.m_re;
	lhs->m_im -= rhs.m_im;
	return *lhs;
}

//此处不再按照正常的复数相乘逻辑 
Complex& __doaml(Complex* lhs, const Complex& rhs)  
{
	lhs->m_re *= rhs.m_re;  
	lhs->m_im *= rhs.m_im;
	return *lhs;
}

Complex& Complex::operator+= (const Complex& rhs)
{
	return __doapl(this, rhs);
}

Complex& Complex::operator-= (const Complex& rhs)
{
	return __doami(this, rhs);
}
Complex Complex::operator* (const Complex& rhs)
{
	return Complex(this->m_re * rhs.m_re, this->m_im * rhs.m_im);
}


Complex& operator*= (Complex& lhs, const Complex& rhs)
{
	return __doaml(&lhs, rhs);
}

Complex operator + (Complex& lhs, const Complex& rhs)
{
	return Complex(lhs.real() + rhs.real(), lhs.real() + rhs.imag());
}

Complex operator - (Complex& lhs, const Complex& rhs)
{
	return Complex(lhs.real() - rhs.real(), lhs.real() - rhs.imag());
}

int main()
{
	Complex c1(3, 3);
	Complex c2(2, 2);
	std::cout << (c1 += c2) << std::endl;
	std::cout << c1 << std::endl;//(5,5)
	std::cout << (c1 -= c2) << std::endl;
	std::cout << c1 << std::endl;
	std::cout << (c1 *= c2) << std::endl;
	std::cout << c1 << std::endl;//(6,6)
	std::cout << "-------------------" << std::endl;
	Complex c3 = c1 + c2;
	std::cout << c3<<std::endl;
	Complex c4 = c1 - c2;
	std::cout << c4 << std::endl;
	Complex c5 = c1 * c2;
	std::cout << c5 << std::endl;

	std::cout << "-------------------" << std::endl;

	c3 = c1 - c2;  // 有默认的复制运算 如果包含指针的话 需要重载
	std::cout << c3 << std::endl;

	
	return 0;


}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值