/*
*Copyright (c)2015,烟台大学计算机与控制工程学院
*All rights reserved.
*文件名称:score.cpp
*作 者:惠睿
*完成日期:2015年4月29日
*版 本 号:v1.0
*
*问题描述:。
*程序输入:无输入。
*程序输出:输出调用函数后的值。
*/
#include<iostream>
using namespace std;
class Complex
{
public:
Complex()
{
real=0;
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 Complex operator+(double &d,const Complex &c);
friend Complex operator-(double &d,const Complex &c);
friend Complex operator*(double &d,const Complex &c);
friend Complex operator/(double &d,const Complex &c);
Complex operator+(double &d);
Complex operator-(double &d);
Complex operator*(double &d);
Complex operator/(double &d);
void display();
private:
double real;
double 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);
}
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)
{
int t;
t=c1.real*c2.real+c1.real*c2.imag+c1.imag*c2.real-c1.imag*c2.imag;
return Complex((c1.real*c2.real-c1.imag*c2.imag)/t,(c1.real*c2.imag+c1.imag*c2.real)/t);
}
Complex Complex::operator+(double &d)
{
return Complex(real+d,imag);
}
Complex Complex::operator-(double &d)
{
return Complex(real-d,imag);
}
Complex Complex::operator*(double &d)
{
return Complex(real*d,imag*d);
}
Complex Complex::operator/(double &d)
{
return Complex(real/d,imag/d);
}
Complex operator+(double &d,const Complex &c)
{
return Complex(d+c.real,c.imag);
}
Complex operator-(double &d,const Complex &c)
{
return Complex(d-c.real,c.imag);
}
Complex operator*(double &d,const Complex &c)
{
return Complex(d*c.real,d*c.imag);
}
Complex operator/(double &d,const Complex &c)
{
Complex c1,c2;
int t;
c1.real=c.real;
c1.imag=(-1)*c.imag;
t=c1.real*c.real+c1.real*c.imag+c1.imag*c.real-c1.imag*c.imag;;
c2.real=(d*c.real)/t;
c2.imag=(d*(-1)*c.imag)/t;
return Complex(c2);
}
void Complex::display()
{
cout<<"("<<real<<","<<imag<<"i)"<<endl;
}
int main()
{
Complex c1(3,4),c2(5,-10),c3;
double d=2,t=3;
cout<<"c1=";
c1.display();
cout<<"c2=";
c2.display();
c3=c1+c2;
cout<<"c1+c2=";
c3.display();
c3=c1-c2;
cout<<"c1-c2=";
c3.display();
c3=c1*c2;
cout<<"c1*c2=";
c3.display();
c3=c1/c2;
cout<<"c1/c2=";
c3.display();
c3=c1+d;
c3.display();
c3=c1-d;
c3.display();
c3=c1*d;
c3.display();
c3=c1/d;
c3.display();
c3=t+c1;
c3.display();
c3=t-c1;
c3.display();
c3=t*c1;
c3.display();
c3=t/c1;
c3.display();
return 0;
}
运行结果: