第八周项目-1.3

#include<iostream>
using namespace std;
class Complex
{
public:
Complex(){ real = 0; imag = 0; }
Complex(double r, double i){ real = r; imag = i; }
Complex operator+(const Complex &c2);
Complex operator-(const Complex &c2);
Complex operator*(const Complex &c2);
Complex operator/(const Complex &c2);
friend Complex operator+(const double &c1,const Complex &c2);
friend  Complex operator-(const double &c1,const Complex &c2);
friend
Complex operator*(const double &c1,const Complex &c2);
friend
Complex operator/(const double &c1,const Complex &c2);
friend Complex operator+(const Complex &c1,const double &c2);
friend  Complex operator-(const Complex &c1,const double &c2);
friend
Complex operator*(const Complex &c1,const double &c2);
friend
Complex operator/(const Complex &c1,const double &c2);
void display();
private:
double real;
double imag;
};
//下面定义成员函数
Complex Complex::operator+(const Complex &c2)
{
return Complex(real + c2.real, imag + c2.imag);
}
Complex Complex::operator-(const Complex &c2)
{
return Complex(real – c2.real, imag – c2.imag);
}
Complex Complex::operator*(const Complex &c2)
{
return Complex(real*c2.real – imag*c2.imag, real*c2.imag + imag*c2.real);
}
{
return Complex((real*c2.real + imag*c2.imag) / (c2.real*c2.real + c2.imag*c2.imag), (imag*c2.real – real*c2.imag) / (c2.real*c2.real + c2.imag*c2.imag));
}
Complex operator+(const double &c1, const Complex &c2)
{
return Complex(c1 + c2.real, c2.imag);
}
Complex operator-(const double &c1, const Complex &c2)
{
return Complex(c1 – c2.real, c2.imag);
}
Complex operator*(const double &c1, const Complex &c2)
{
return Complex(c1 * c2.real, c2.imag);
}
Complex operator/(const double &c1, const Complex &c2)
{
return Complex(c1 / c2.real, c2.imag);
}
Complex operator+(const Complex &c1, const double &c2)
{
return Complex(c1.real + c2, c1.imag);
}
Complex operator-(const Complex &c1, const double &c2)
{
return Complex(c1.real – c2, c1.imag);
}
Complex operator*(const Complex &c1, const double &c2)
{
return Complex(c1.real * c2, c1.imag);
}
Complex operator/(const Complex &c1, const double &c2)
{
return Complex(c1.real / c2, c1.imag);
}
void Complex::display()
{
if (imag == 0)
cout << real << endl;
else if (imag < 0)
cout << real << " – " << -imag << "i" << endl;
else
cout << real << " + " << imag << "i" << endl;
}
//下面定义用于测试的main()函数
int main()
{
Complex c1(3, 4), c2(5, ⑴0), c3;
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 + 3;
cout << "c1 + 3=";
c3.display();
c3 = ⑸ + c2;
cout << "⑸ + c2=";
c3.display();//———————–  +
c3 = c1 – 3;
cout << "c1 – 3=";
c3.display();
c3 = ⑸ – c2;
cout << "⑸ – c2=";
c3.display();//———————-  –
c3 = c1 * 3;
cout << "c1 * 3=";
c3.display();
c3 = ⑸ * c2;
cout << "⑸ * c2=";
c3.display();//———————-  *
c3 = c1 / 3;
cout << "c1 / 3=";
c3.display();
c3 = ⑸ / c2;
cout << "⑸ / c2=";
c3.display();//———————  /
while (1){}
return 0;
}

1. 本站所有资源来源于用户上传和网络，如有侵权请邮件联系站长！
2. 分享目的仅供大家学习和交流，您必须在下载后24小时内删除！
3. 不得使用于非法商业用途，不得违反国家法律。否则后果自负！
4. 本站提供的源码、模板、插件等等其他资源，都不包含技术服务请大家谅解！
5. 如有链接无法下载、失效或广告，请联系管理员处理！
6. 本站资源售价只是赞助，收取费用仅维持本站的日常运营所需！
7. 如遇到加密压缩包，请使用WINRAR解压,如遇到无法解压的请联系管理员！