感想:这题本身的算法不难,难的是细节的处理,只保留一位小数,这个应该怎么做,而且,运算后的结果,对于实部或者是虚部,像0.0x或-0.0x,x范围为0~9,保留1位小数后,即使x>=5也不进位,而是当0处理,up主觉得难的就难在这里,也是看了别人的代码才得出当进行相应的运算后如果实部或虚部是0.0x或-0.0x,当x>=5,都不进位。而对于原始的输入数据,该进位还是要进位
代码(别人写的)
#include<bits/stdc++.h>
using namespace std;
double a1,b1,a2,b2;
void Judge_op(string&,string&);
void Output(double,double);
void Plus();
void Minus();
void Multiply(); //(a+bi)*(c+di) ==> (ac-bd)+(ad+bc)
void Divide();
int main()
{
cin>>a1>>b1>>a2>>b2;
string op1,op2;
Judge_op(op1,op2);
cout<<setiosflags(ios::fixed)<<setprecision(1)<<'('<<a1<<op1<<b1<<"i) "<<"+ ("<<a2<<op2<<b2<<"i) = ";
Plus();cout<<'\n';
cout<<setiosflags(ios::fixed)<<setprecision(1)<<'('<<a1<<op1<<b1<<"i) "<<"- ("<<a2<<op2<<b2<<"i) = ";
Minus();cout<<'\n';
cout<<setiosflags(ios::fixed)<<setprecision(1)<<'('<<a1<<op1<<b1<<"i) "<<"* ("<<a2<<op2<<b2<<"i) = ";
Multiply();cout<<'\n';
cout<<setiosflags(ios::fixed)<<setprecision(1)<<'('<<a1<<op1<<b1<<"i) "<<"/ ("<<a2<<op2<<b2<<"i) = ";
Divide();cout<<'\n';
return 0;
}
void Judge_op(string &op1,string &op2)
{
if(b1>=0)
op1="+";
else
op1="";
if(b2>=0)
op2="+";
else
op2="";
}
void Plus()
{
double real=a1+a2;
double imag=b1+b2;
Output(real,imag);
}
void Minus()
{
double real=a1-a2;
double imag=b1-b2;
Output(real,imag);
}
void Multiply()
{
double real=a1*a2-b1*b2;
double imag=a1*b2+a2*b1;
Output(real,imag);
}
void Divide()
{
double deno=a2*a2+b2*b2;
double real=(a1*a2+b1*b2)/deno;
double imag=(a2*b1-a1*b2)/deno;
Output(real,imag);
}
void Output(double real,double imag)
{
if((int)(real*10)==0)
{
if((int)(imag*10)==0)
cout<<0.0;
else
cout<<setiosflags(ios::fixed)<<setprecision(1)<<imag<<'i';
}
else if((int)(imag*10)==0)
cout<<setiosflags(ios::fixed)<<setprecision(1)<<real;
else
{
cout<<setiosflags(ios::fixed)<<setprecision(1)<<real;
if(imag>=0)
cout<<'+';
cout<<setiosflags(ios::fixed)<<setprecision(1)<<imag<<'i';
}
}
/*
0.0x 当x即使大于等于5 也不舍入
*/