Problem Description
定义一个复数类Complex,重载运算符“+”,使之能用于复数的加法运算。参加运算的两个运算量可以都是类对象,也可以其中有一个是整数,顺序任意。例如:c1+c2、i+c1、c1+i均合法。(其中i是整数,c1、c2是复数),编程实现求2个复数之和、整数与复数之和。
Input
输入有三行:第1行是第1个复数c1的实部和虚部,以空格分开。第2行是第2个复数c2的实部和虚部,以空格分开。第3行是1个整数i的值。
Output
输出有三行:
第1行是2个复数c1和c2的和,显示方式:实部+虚部i
第2行是第1个复数c1加i的值,显示方式:实部+虚部i
第3行是i加第1个复数c1的值,显示方式:实部+虚部i
Example Input
2 3
3 5
10
Example Output
5+8i
12+3i
12+3i
注释代码是重载+实现:复数的实部和实数之和
#include<bits/stdc++.h>
using namespace std;
class node
{
public:
node(double n = 0, double m = 0) {
x = n, y = m;
}
node operator + (const node &b);
node operator + (const int b);
// double operator + (const double b);
friend node operator + (const int a, const node &b);
friend ostream & operator << (ostream &out, const node &b);
private:
double x, y;
};
node node::operator + (const node &b)
{
node t;
t.x = x + b.x;
t.y = y + b.y;
return t;
}
node node::operator + (int b)
{
node t;
t.x = x + b;
t.y = y;
return t;
}
/*double node::operator+(const double b)
{
double t = x + b;
return t;
}*/
node operator + (const int a, const node &b)
{
node t;
t.x = a + b.x;
t.y = b.y;
return t;
}
ostream & operator << (ostream &out, const node &b)
{
out << b.x;
if(b.y > 0) out << '+';
if(b.y != 0)
out << b.y << 'i' ;
return out;
}
int main()
{
double x, y, x1, y1;
int num;
cin >> x >> y >> x1 >> y1;
node a(x, y), b(x1, y1);
cin >> num;
cout << a+b << endl;
cout << a+num << endl;
cout << num+a << endl;
/* double num1;
cin >> num1;
cout << a+num1 << endl;*/
}