-
Notifications
You must be signed in to change notification settings - Fork 9
/
Copy pathcomplexOperatorOverload.cpp
91 lines (74 loc) · 1.48 KB
/
complexOperatorOverload.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
#include <iostream>
using namespace std;
class complex
{
float a,b;
public:
complex(){a=0;b=0;}
complex(float x, float y)
{
a = x;
b = y;
}
void display()
{
cout << a << " + i" << b << endl;
}
friend complex operator +(complex &o1, complex &o2);
friend complex operator -(complex &o1, complex &o2);
friend complex operator *(complex &o1, complex &o2);
friend complex operator /(complex &o1, complex &o2);
};
complex operator +(complex &o1, complex &o2)
{
complex result;
result.a = o1.a + o2.a;
result.b = o1.b + o2.b;
return result;
}
complex operator -(complex &o1, complex &o2)
{
complex result;
result.a = o1.a - o2.a;
result.b = o1.b - o2.b;
return result;
}
complex operator *(complex &o1, complex &o2)
{
complex result;
float p,q,r,s;
p = o1.a * o2.a;
q = -(o1.b * o2.b);
r = o1.a * o2.b;
s = o1.b * o2.a;
result.a = p + q;
result.b = r + s;
return result;
}
complex operator /(complex &o1, complex &o2)
{
complex result, p, q, r;
p = o2;
p.b = -(p.b);
q = o1*p;
r = o2*p;
result.a = q.a/r.a;
result.b = q.b/r.a;
return result;
}
int main()
{
float a,b,c,d;
complex result;
cin >> a >> b >> c >> d;
complex x(a,b), y(c,d);
result = x+y;
result.display();
result = x-y;
result.display();
result = x*y;
result.display();
result = x/y;
result.display();
return 0;
}