题目描述
复数类的声明如下:
class Complex
{
private:
double real; // 实部
double imag; // 虚部
public:
Complex();
Complex(double r, double i);
// 友元函数,复数c1 + c2(二参数对象相加)
friend Complex addCom(const Complex& c1, const Complex& c2);
// 友元函数,输出类对象c的有关数据(c为参数对象)
friend void outCom(const Complex& c);
};
要求如下:
1. 实现复数类和友元函数addCom和outCom。
2. 参考addCom函数为复数类增加一个友元函数minusCom,用于实现两个复数的减法
3. 在main函数中,通过友元函数,实现复数的加减法和复数的输出。
输入
第1行:第1个复数的实部和虚部
第2行:需进行运算的次数,注意:是连续运算。具体结果可参考样例
第3行开始,每行输入运算类型,以及参与运算的复数的实部与虚部。“+”表示复数相加,“-”表示复数相减。
输出
每行输出复数运算后的结果,复数输出格式为“(实部,虚部)”。
输入样例1
10 10
3
+ 20 10
- 15 5
+ 5 25
输出样例1
(30,20)
(15,15)
(20,40)
该题目主要考察对友元函数的应用
#include<iostream>
#include<algorithm>
#include<string>
#include<vector>
#include <iomanip>
#include<cmath>
#include<cstring>
#include<cctype>
#include<queue>
#include<set>
using namespace std;
class Complex
{
private:
double real; // 实部
double imag; // 虚部
public:
Complex() { ; }
Complex(double r, double i);
// 友元函数,复数c1 + c2(二参数对象相加)
friend Complex subCom(const Complex& c1, const Complex& c2);
friend Complex addCom(const Complex& c1, const Complex& c2);
// 友元函数,输出类对象c的有关数据(c为参数对象)
friend void outCom(const Complex& c);
};
void outCom(const Complex& c)
{
cout << '(' << c.real << ',' << c.imag << ')' << endl;
}
Complex addCom(const Complex& c1, const Complex& c2)
{
Complex t;
t.real = c1.real + c2.real;
t.imag = c1.imag + c2.imag;
return t;
}
Complex subCom(const Complex& c1, const Complex& c2)
{
Complex t;
t.real = c1.real - c2.real;
t.imag = c1.imag - c2.imag;
return t;
}
Complex::Complex(double r, double i)
{
real = r;
imag = i;
}
int main()
{
char how;
double r, i;
int n;
cin >> r >> i>>n;
Complex a(r, i);
Complex c;
while (n--)
{
cin >> how >> r >> i;
Complex b(r, i);
if (how == '+')
{
c=addCom(a, b);
outCom(c);
a = c;
}
else if (how == '-')
{
c = subCom(a, b);
outCom(c);
a = c;
}
}
return 0;
}