本题要求编写程序,计算2个复数的和、差、积、商。
输入格式:
输入在一行中按照a1 b1 a2 b2的格式给出2个复数C1=a1+b1i和C2=a2+b2i的实部和虚部。题目保证C2不为0。
输出格式:
分别在4行中按照(a1+b1i) 运算符 (a2+b2i) = 结果的格式顺序输出2个复数的和、差、积、商,数字精确到小数点后1位。如果结果的实部或者虚部为0,则不输出。如果结果为0,则输出0.0。
输入样例1:
2 3.08 -2.04 5.06
输出样例1:
(2.0+3.1i) + (-2.0+5.1i) = 8.1i
(2.0+3.1i) - (-2.0+5.1i) = 4.0-2.0i
(2.0+3.1i) * (-2.0+5.1i) = -19.7+3.8i
(2.0+3.1i) / (-2.0+5.1i) = 0.4-0.6i
输入样例2:
1 1 -1 -1.01
输出样例2:
(1.0+1.0i) + (-1.0-1.0i) = 0.0
(1.0+1.0i) - (-1.0-1.0i) = 2.0+2.0i
(1.0+1.0i) * (-1.0-1.0i) = -2.0i
(1.0+1.0i) / (-1.0-1.0i) = -1.0
#include<iostream>
#include<iomanip>
using namespace std;
float om(float a){float b;
if(a>=0)
{ b=(int(a*10+0.5))/10.0;}
else b=(int(a*10))/10.0;
return b;
}//实现输出之前关于0的检验(多次检验会发现,当sb和xb不为0,但四舍五入为0的情况会给输出造成很大麻烦)
void shuchu(float sb,float xb){
if(om(sb)!=0) {cout<<fixed<<setprecision(1)<<sb;
if(om(xb)>0) cout<<"+"<<fixed<<setprecision(1)<<xb<<"i"<<endl;
else if(om(xb)<0) cout<<fixed<<setprecision(1)<<xb<<"i"<<endl;
else cout<<endl;
}
else {if(om(xb)!=0) cout<<fixed<<setprecision(1)<<xb<<"i"<<endl;
else if(om(xb)==0 )cout<<"0.0"<<endl;}
}//输出要讨论多种情况
void he(float p, float q,float t,float s){
float sb(0.0),xb(0.0);
sb=p+t;
xb=q+s;
if(q>=0&&s>=0)
cout<<"("<<fixed<<setprecision(1)<<p<<"+"<<fixed<<setprecision(1)<<q<<"i) + ("<<t<<"+"<<s<<"i) = ";
else if(s>=0) cout<<"("<<fixed<<setprecision(1)<<p<<fixed<<setprecision(1)<<q<<"i) + ("<<t<<"+"<<s<<"i) = ";
else if(q>=0) cout<<"("<<fixed<<setprecision(1)<<p<<"+"<<fixed<<setprecision(1)<<q<<"i) + ("<<t<<s<<"i) = ";
shuchu(sb,xb);
}
void cha(float p, float q,float t,float s){
float sb(0.0),xb(0.0);
sb=p-t;
xb=q-s;
if(q>=0&&s>=0)
cout<<"("<<p<<"+"<<q<<"i) - ("<<t<<"+"<<s<<"i) = ";
else if(s>=0) cout<<"("<<p<<q<<"i) - ("<<t<<"+"<<s<<"i) = ";
else if(q>=0) cout<<"("<<p<<"+"<<q<<"i) - ("<<t<<s<<"i) = ";
shuchu(sb,xb);
}
void ji(float p, float q,float t,float s){
float sb(0.0),xb(0.0);
sb=p*t-q*s;
xb=p*s+q*t;
if(q>=0&&s>=0)
cout<<"("<<p<<"+"<<q<<"i) * ("<<t<<"+"<<s<<"i) = ";
else if(s>=0) cout<<"("<<p<<q<<"i) * ("<<t<<"+"<<s<<"i) = ";
else if(q>=0) cout<<"("<<p<<"+"<<q<<"i) * ("<<t<<s<<"i) = ";
shuchu(sb,xb);
}
void shang(float p, float q,float t,float s){
float sb(0.0),xb(0.0);
float sum;
sum=t*t+s*s;
sb=(p*t+q*s)/sum;
xb=(-p*s+q*t)/sum;
if(q>=0&&s>=0)
cout<<"("<<p<<"+"<<q<<"i) / ("<<t<<"+"<<s<<"i) = ";
else if(s>=0) cout<<"("<<p<<q<<"i) / ("<<t<<"+"<<s<<"i) = ";
else if(q>=0) cout<<"("<<p<<"+"<<q<<"i) / ("<<t<<s<<"i) = ";
shuchu(sb,xb);
}
int main(){
float a,b,c,d;
cin>>a>>b>>c>>d;
float sb,xb;
he(a,b,c,d);
cha(a,b,c,d);
ji(a,b,c,d);
shang(a,b,c,d);
return 0;
}