C++第六节之运算符重载(复数运算)

在C++中,运算符 + - * / 已有了规定,只能运算整数型,浮点型,其中+ - 在一定范围内可以对字符型进行运算,如果需要对复数,分数或者其他操作数作四则运算,就要对他们进行重新定义这就是运算符重载的含义
运算符重载是为了满足某种操作的需求,在原有运算符实现不了,又不增加新的运算符种类基础上,对相近意义上的运算符进行重载

大多数运算符都可以重载只有少数不可以 ,分别为:
.    成员访问运算符
.*   成员指针访问运算符
::   域运算符
sizeof   尺寸运算符
?:    条件运算符

运算符重载函数

两种形式:  成员函数形式
          <类型> operator <运算符> (< 参数表>)
          {      }
 一般来说,单目运算符采用成员函数重载时,参数表是无参数的,双目运算符重载时只有一个参数隐藏了一个参数,this指针,即指向该成员函数对象的指针
          友元函数形式
          friend <类型> operator <运算符> (< 参数表>)
          {      }
 一般来说,单目运算符采用友元函数重载时,参数表是有一个参数的,双目运算符重载时有两个参数,因为友元函数中没有this指针
        
#include <iostream>
using namespace std;
class complex
{
public:
	complex()
	{
		_real = 0.0;
		_imag = 0.0;
     }
	complex(double real)
	{
		_real = real;
		_imag = 0.0;
     }
	complex(double real, double imag)
	{
		_real = real;
		_imag = imag;
	}
	complex operator + (const complex& c);//运算符重载函数声明
	complex operator - (const complex& c);
	complex operator * (const complex& c);
	complex operator / (const complex& c);
	friend void print(const complex& c);//友元函数

private :
	double _real;
	double _imag;
};
inline complex complex::operator +(const complex& c)
{//  inline修饰成内联函数
            //complex R;
	        //R._real = _real + c._real;
	        //R._imag = _imag + c._imag;
	        //return R;
优化后:
    return complex(_real + c._real, _imag + c._imag);
}
inline complex complex::operator -(const complex& c)
{
	return complex(_real - c._real, _imag - c._imag);
}
inline complex complex::operator *(const complex& c)
{
	return complex(_real * c._real-_imag*c._imag, _real*c._imag + _imag*c._real);
}
inline complex complex::operator /(const complex& c)
{
	return complex((_real*c._real + _imag*c._imag)/(c._real*c._real+c._imag*c._imag),
		(_imag*c._real-_real*c._imag)/(c._real*c._real + c._imag*c._imag));
}
void print(const complex& c)
{
	if (c._imag < 0)
		cout << c._real << c._imag << "i";
	else
		cout << c._real <<"+"<< c._imag << "i";

}
void main()
{
	complex c1(2.0);
	complex c2(3.0, -1);
	complex c3 = c1 + c2;
	cout << "\n c1 + c2 = ";
	print(c3);
    c3 = c1 - c2;
	cout << "\n c1 - c2 = ";
	print(c3);
    c3 = c1 * c2;
	cout << "\n c1 * c2 = ";
	print(c3);
    c3 = c1 / c2;
	cout << "\n c1 / c2 = ";
	print(c3);

	cout << endl;
}
程序中c1+c2中加法为被重载后的复数加法运算 ,表达式可以理解为
c1.operator + (c2)//c1为第一操作数。c2为第二操作数

友元函数实现运算符重载

friend complex operator -(const complex& c1,const complex& c2);//类内声明
  complex operator -(const complex& c1,const complex& c2)//类外定义
  {
  return complex(_real - c._real, _imag - c._imag);
  }
  
  程序中c1-c2中减法为被重载后的复数减运算 ,表达式可以理解为
     operator- (c1,c2)

一般来说,单目运算符重载常选用成员函数,双目运算符重载常选用友元函数

eg:
    1.0 + c1;    c1为类的对象
    成员函数理解为: 1.0.operator + (c1) 显然是错误的
    友元函数理解为:  operator +(complex(1.0) ,c1)
    
  • 1
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我可以帮你解答这个问题。以下是一个简单的复数类的代码示例,其中包括了算术四则运算符的重载实现。 ```c++ #include <iostream> using namespace std; class Complex { public: Complex(double real = 0.0, double imag = 0.0) : re(real), im(imag) {} Complex operator+(const Complex& c) const { return Complex(re + c.re, im + c.im); } Complex operator-(const Complex& c) const { return Complex(re - c.re, im - c.im); } Complex operator*(const Complex& c) const { return Complex(re * c.re - im * c.im, re * c.im + im * c.re); } Complex operator/(const Complex& c) const { double denominator = c.re * c.re + c.im * c.im; return Complex((re * c.re + im * c.im) / denominator, (im * c.re - re * c.im) / denominator); } friend ostream& operator<<(ostream& os, const Complex& c) { os << "(" << c.re << ", " << c.im << "i)"; return os; } private: double re, im; }; int main() { Complex a(1.0, 2.0); Complex b(3.0, 4.0); Complex c = a + b; Complex d = a - b; Complex e = a * b; Complex f = a / b; cout << "a + b = " << c << endl; cout << "a - b = " << d << endl; cout << "a * b = " << e << endl; cout << "a / b = " << f << endl; return 0; } ``` 在这个示例中,我们定义了一个复数类 `Complex`,其中包含实部和虚部两个私有数据成员。我们通过重载运算符 `+`、`-`、`*` 和 `/` 来实现了相应的算术四则运算。此外,我们还定义了一个友元函数 `operator<<`,用于输出复数类对象的值。 在 `main` 函数中,我们创建了两个 `Complex` 类对象 `a` 和 `b`,并对其进行了加、减、乘、除四种运算操作。最后,我们通过 `cout` 输出了运算结果。 希望这个示例能够帮助你了解如何利用重载运算符实现复数类对象的算术四则运算。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值