1051 复数乘法 (15 分)
复数可以写成 (A+Bi) 的常规形式,其中 A 是实部,B 是虚部,i 是虚数单位,满足 i2=−1i^2=-1i2=−1;也可以写成极坐标下的指数形式 (R×e(Pi)R×e^{(Pi)}R×e(Pi)),其中 R 是复数模,P 是辐角,i 是虚数单位,其等价于三角形式 R(cos(P)+isin(P))R(\cos(P)+i\sin(P))R(cos(P)+isin(P))。
现给定两个复数的 R 和 P,要求输出两数乘积的常规形式。
输入格式:
输入在一行中依次给出两个复数的 R1,P1,R2,P2R_1,P_1,R_2,P_2R1,P1,R2,P2,数字间以空格分隔。
输出格式:
在一行中按照A+Bi
的格式输出两数乘积的常规形式,实部和虚部均保留 2 位小数。注意:如果 B 是负数,则应该写成A-|B|i
的形式。
输入样例:
2.3 3.5 5.2 0.4
输出样例:
-8.68-8.23i
题解
通过题目描述,可知有如下关于复数从极坐标转直角坐标的关系式:
R∗ePi=RcosP+RsinPiR*e^{Pi}=R\cos P + R\sin P iR∗ePi=RcosP+RsinPi
相当于AAA~RcosPR\cos PRcosP、BBB~RsinPiR\sin P iRsinPi。
直角坐标系下两复数相乘可得到如下推导:
(A1+B1i)(A2+B2i)=(A1A2−B1B2)+(A1B2+A2B1)i
\begin{aligned}
&(A_1+B_1i)(A_2+B_2i)\\
&=(A_1A_2-B_1B_2)+(A_1B_2+A_2B_1)i
\end{aligned}
(A1+B1i)(A2+B2i)=(A1A2−B1B2)+(A1B2+A2B1)i
交叉相乘展开后,对于实部通过和差公式有:
A=A1A2−B1B2=r1r2(cosP1cosP2−sinP1sinP2)=r1r2cos(P1+P2)
\begin{aligned}
A&=A_1A_2-B_1B_2\\
&=r_1r_2(\cos P_1\cos P_2-\sin P_1\sin P_2)\\
&=r_1r_2\cos (P_1+P_2)
\end{aligned}
A=A1A2−B1B2=r1r2(cosP1cosP2−sinP1sinP2)=r1r2cos(P1+P2)
同样的,对于复数部分,有:
B=A1B2+A2B1=r1r2(cosP1sinP2+cosP2sinP1)=r1r2sin(P1+P2)
\begin{aligned}
B&=A_1B_2+A_2B_1\\
&=r_1r_2(\cos P_1\sin P_2+\cos P_2\sin P_1)\\
&=r_1r_2\sin (P_1+P_2)
\end{aligned}
B=A1B2+A2B1=r1r2(cosP1sinP2+cosP2sinP1)=r1r2sin(P1+P2)
综上,最后的计算结果就是:
A+Bi=r1r2cos(P1+P2)+r1r2sin(P1+P2)iA+Bi=r_1r_2\cos (P_1+P_2)+r_1r_2\sin (P_1+P_2)iA+Bi=r1r2cos(P1+P2)+r1r2sin(P1+P2)i
输出的时候注意,实部和虚部无论是不是0.00都要输出。此外,在printf四舍五入的时候,-0.001是会输出-0.00,注意这种情况出现时输出正的0.00。
数据点3不过就是出现了-0.00的情况,可以写一个判断来处理。
AC例程
#include<iostream>
#include <stdio.h>
#include <math.h>
using namespace std;
int main()
{
float r1,p1,r2,p2;
cin>>r1>>p1>>r2>>p2;
double A=1.0*r1*r2*cos(p1+p2),B=1.0*r1*r2*sin(p1+p2);
if (A<0&&A>-0.005)printf("%.2f",-A);
else printf("%.2f",A);
if(B>=0.005){cout<<'+';printf("%.2fi",B);}
else if(B<=-0.005){
printf("%.2fi",B);
}else printf("+0.00i\n");
return 0;
}