网易云课堂_C++程序设计入门(下)_第9单元:白公曾咏牡丹芳,一种鲜妍独“异常”_第9单元

第9单元 - 作业2:OJ编程 - 修改附属类,重载加减法运算符

�返回
 

温馨提示:

1.本次作业属于Online Judge题目,提交后由系统即时判分。

2.学生可以在作业截止时间之前不限次数提交答案,系统将取其中的最高分作为最终成绩。

练习运算符重载
完善复数的输出显示

依照学术诚信条款,我保证此作业是本人独立完成的。

1
练习运算符重载(5分)

本作业是对作业2的修订:请勿在作业2中提交作业,请在本作业中提交作业2的程序

具体内容,参见 【第9单元 - 作业2说明:【OJ - 修改复数类,重载加减法运算符】】

时间限制:500ms内存限制:32000kb
 
#include <iostream>
#include <cstdlib>
#include <limits>
#include <iomanip>
#include <cmath>

using namespace std;

class MyComplex//2. 创建一个类 MyComplex,用来表示复数。
{
public:
	MyComplex();
	MyComplex(double a, double b);

	friend ostream& operator <<(ostream& os, const MyComplex& z);//4. 重载流插入运算符 << ,使之可以将复数输出为如下的格式(实部如果是非负数,则不输出符号位;输出时要包含半角左右小括号):
	friend istream& operator >> (istream& is, MyComplex& z);//3. 重载流提取运算符 >> ,使之可以读入以下格式的输入(两个数值之间使用空白分隔),将第一个数值存为复数的实部,将第二个数值存为复数的虚部:

	MyComplex operator+(const MyComplex &secondMyComplex);//加法法则:(a+bi)+(c+di)=(a+c)+(b+d)i;
	MyComplex operator-(const MyComplex &secondMyComplex);//减法法则:(a+bi)-(c+di)=(a-c)+(b-d)i;
	MyComplex operator*(const MyComplex &secondMyComplex);//乘法法则:(a+bi)·(c+di)=(ac-bd)+(bc+ad)i;
	MyComplex operator/(const MyComplex &secondMyComplex);//除法法则:(a+bi)÷(c+di)=[(ac+bd)/(c²+d²)]+[(bc-ad)/(c²+d²)]i.

private:
	double a_;
	double b_;
};

MyComplex::MyComplex()
{
}

MyComplex::MyComplex(double a, double b)
{
	a_ = a;
	b_ = b;
}

ostream & operator<<(ostream & os, const MyComplex & z)//4. 重载流插入运算符 << ,使之可以将复数输出为如下的格式(实部如果是非负数,则不输出符号位;输出时要包含半角左右小括号):
{
	// TODO: 在此处插入 return 语句
	os.unsetf(std::ios::showpos);

	os << "(" << z.a_;

	os.setf(std::ios::showpos);

	os << z.b_ << "i)";

	return os;
}

istream & operator >> (istream & is, MyComplex & z)//3. 重载流提取运算符 >> ,使之可以读入以下格式的输入(两个数值之间使用空白分隔),将第一个数值存为复数的实部,将第二个数值存为复数的虚部:
{
	// TODO: 在此处插入 return 语句
	is >> z.a_ >> z.b_;
	return is;
}

MyComplex MyComplex::operator+(const MyComplex & secondMyComplex)//加法法则:(a+bi)+(c+di)=(a+c)+(b+d)i;
{
	return MyComplex(a_ + secondMyComplex.a_, b_ + secondMyComplex.b_);
}

MyComplex MyComplex::operator-(const MyComplex & secondMyComplex)//减法法则:(a+bi)-(c+di)=(a-c)+(b-d)i;
{
	return MyComplex(a_ - secondMyComplex.a_, b_ - secondMyComplex.b_);
}

MyComplex MyComplex::operator*(const MyComplex & secondMyComplex)//乘法法则:(a+bi)·(c+di)=(ac-bd)+(bc+ad)i;
{
	return MyComplex(a_ * secondMyComplex.a_ - b_ * secondMyComplex.b_, secondMyComplex.a_ * b_ + a_ * secondMyComplex.b_);
}

MyComplex MyComplex::operator/(const MyComplex & secondMyComplex)//除法法则:(a+bi)÷(c+di)=[(ac+bd)/(c²+d²)]+[(bc-ad)/(c²+d²)]i.
{
	if (pow(secondMyComplex.a_, 2) + pow(secondMyComplex.b_, 2) == 0)//2. 在做除法时,如果除数是0,则输出一条信息:“Divisor can not be 0” (注意:请精确复制这段信息,否则即便你的程序逻辑正确,OJ系统仍然会判你失败。输出信息中不包含引号)然后结束程序(调用 exit() 函数),直接退出(注意,传递给操作系统的返回值与main函数正常结束时相同,仍然为0)。
	{
		cout << "Divisor can not be 0";
		exit(0);
	}

	return MyComplex((a_ * secondMyComplex.a_ + b_ * secondMyComplex.b_) / (pow(secondMyComplex.a_, 2) + pow(secondMyComplex.b_, 2)), (b_ * secondMyComplex.a_ - a_ * secondMyComplex.b_) / (pow(secondMyComplex.a_, 2) + pow(secondMyComplex.b_, 2)));
}

int main() {
	MyComplex z1, z2;
	cin >> z1;
	cin >> z2;
	cout << "z1 + z2 = " << z1 + z2 << endl;
	cout << "z1 - z2 + z1 = " << z1 - z2 + z1 << endl;
	cout << "z1 * z2 - z1 = " << z1 * z2 - z1 << endl;
	cout << "z1 / z2 + z1 = " << z1 / z2 + z1 << endl;
	cout << "z2 - z1 / z1 = " << z2 - z1 / z1;
	// GCC及VC编译器在调试模式下会暂停,便于查看运行结果
#if ( defined(__DEBUG__) || defined(_DEBUG) )
	cin.ignore(numeric_limits<streamsize>::max(), '
');
	cin.get();
#endif
	return 0;
}
原文地址:https://www.cnblogs.com/denggelin/p/7136639.html