简单的运算符重载---复数加减乘除

//complex.h

#pragma once

#include <stdio.h>

class Complex
{
public:
	Complex()
	{
		real = 0;
		imag = 0;
	}

	Complex(double real, double imag)
	{
		this->real = real;
		this->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;
};

class complex
{
public:
	complex() { real=imag=0; }
	complex(double r, double i)
	{
		real = r, imag = i;
	}

	friend complex operator +(const complex &c1, const complex &c2);
	friend complex operator -(const complex &c1, const complex &c2);
	friend complex operator *(const complex &c1, const complex &c2);
	friend complex operator /(const complex &c1, const complex &c2);
	friend void display(const complex &c);

private:
	double real, imag;
};

class CharArray
{
public:
	CharArray(int l)
	{
		if (l < 1)
		{
			Buff = NULL;
		}
		else
		{
			Length = l;
			Buff = new char[Length];
		}
	}
	int GetLength() 
	{ 
		return Length; 
	}
	char & operator [](int i);
	~CharArray() 
	{ 
		if (Buff != NULL)
		{
			delete Buff; 
		}
	}

private:
	int Length;
	char * Buff;
};
//complex.cpp

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

using namespace std;

inline Complex Complex::operator+(const Complex &c)
{
	//cout<<"class +"<<endl;
	return Complex(this->real + c.real, this->imag + c.imag);
}

inline Complex Complex::operator-(const Complex &c)
{
	return Complex(this->real - c.real, this->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));
}

extern void print(const Complex &c)
{
	if(c.imag < 0)
	{
		cout<<c.real<<c.imag<<'i';
	}
	else
	{
		cout<<c.real<<'+'<<c.imag<<'i';
	}
}

extern void ComplexTest()
{
	Complex c1(2.0, 3.0), c2(4.0, -2.0), c3;
		
	cout<<"c1 = ";
	print(c1);
	cout<<endl;
	cout<<"c2 = ";
	print(c2);

	c3 = c1 + c2;
	cout<<endl<<"c1 + c2 = ";
	print(c3);

	c3 = c1 - c2;
	cout<<endl<<"c1 - c2 = ";
	print(c3);

	c3 = c1 * c2;
	cout<<endl<<"c1 * c2 = ";
	print(c3);

	c3 = c1 / c2;
	cout<<endl<<"c1 / c2 = ";
	print(c3);

	c3 = (c1+c2) * (c1-c2) * c2/c1;
	cout<<endl<<"(c1+c2)*(c1-c2)*c2/c1=";
	print(c3);
	cout<<endl;
}

complex operator +(const complex &c1, const complex &c2)
{
	//cout<<"friend +"<<endl;
	return complex(c1.real + c2.real, c1.imag + c2.imag);
}

complex operator -(const complex &c1, const complex &c2)
{
	return complex(c1.real - c2.real, c1.imag - c2.imag);
}

complex operator *(const complex &c1, const complex &c2)
{
	return complex(c1.real * c2.real - c1.imag * c2.imag, c1.real * c2.imag + c1.imag * c2.real);
}

complex operator /(const complex &c1, const complex &c2)
{
	return complex((c1.real * c2.real + c1.imag * c2.imag) / (c2.real * c2.real + c2.imag * c2.imag), (c1.imag * c2.real - c1.real * c2.imag) / (c2.real * c2.real + c2.imag * c2.imag));
	//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 display(const complex &c)
{
	if(c.imag < 0)
	{
		cout<<c.real<<c.imag<<'i';
	}
	else
	{
		cout<<c.real<<'+'<<c.imag<<'i';
	}
}

extern void complexTest()
{
	complex c1(2.0, 3.0), c2(4.0, -2.0), c3;

	cout<<"c1 = ";
	display(c1);
	cout<<endl;
	cout<<"c2 = ";
	display(c2);

	c3 = c1 + c2;
	cout<<endl<<"c1 + c2 = ";
	display(c3);

	c3 = c1 - c2;
	cout<<endl<<"c1 - c2 = ";
	display(c3);

	c3 = c1 * c2;
	cout<<endl<<"c1 * c2 = ";
	display(c3);

	c3 = c1 / c2;
	cout<<endl<<"c1 / c2 = ";
	display(c3);

	c3 = (c1+c2) * (c1-c2) * c2/c1;
	cout<<endl<<"(c1+c2)*(c1-c2)*c2/c1=";
	display(c3);
	cout<<endl;
}

char & CharArray::operator[](int i)
{
	static char ch = '\0';
	if(i < Length && i >= 0)
	{
		return Buff[i];
	}
	else
	{
		cout<<"Index out of range."<<endl;
		return ch;
	}
}

void CharArrayTest()
{
	int cnt;
	CharArray string1(6);
	char * string2 = "string";

	for(cnt=0; cnt < 8; cnt++)
		string1[cnt] = string2[cnt];
	cout<<endl;

	for(cnt=0; cnt < 8; cnt++)
		cout<<string1[cnt]<<endl;
	cout<<endl;

	cout<<string1.GetLength()<<endl;

}


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值