1051 复数乘法 (15 分)
复数可以写成 (A+Bi) 的常规形式,其中 A 是实部,B 是虚部,i 是虚数单位,满足 i 2 =−1;也可以写成极坐标下的指数形式 (R×e (Pi)),其中 R 是复数模,P 是辐角,i 是虚数单位,其等价于三角形式 R(cos§+isin§)。
现给定两个复数的 R 和 P,要求输出两数乘积的常规形式。
输入格式:
输入在一行中依次给出两个复数的R1,P1,R2,P2,数字间以空格分隔。
输出格式:
在一行中按照 A+Bi 的格式输出两数乘积的常规形式,实部和虚部均保留 2 位小数。注意:如果 B 是负数,则应该写成 A-|B|i 的形式。
输入样例:
2.3 3.5 5.2 0.4
结尾无空行
输出样例:
-8.68-8.23i
结尾无空行
#include<stdio.h>
#include<math.h>
int main(){
double a,ai,b,bi,A,B;
scanf("%lf %lf %lf %lf",&a,&ai,&b,&bi);
A=a*b*cos(ai)*cos(bi)-a*b*sin(ai)*sin(bi);
B=a*b*cos(ai)*sin(bi)+a*b*sin(ai)*cos(bi);
if (A + 0.005 >= 0 && A < 0)
printf("0.00");
else
printf("%.2f", A);
if(B >= 0)
printf("+%.2fi", B);
else if (B + 0.005 >= 0 && B < 0)
printf("+0.00i");
else
printf("%.2fi", B);
return 0;
}
分析
首先(a+bi)(c+di)=(ac-bd)(ad+bc)i
由题意得a+bi等价于Rcos(P)+Rsin(P)i
则a=Rcos(P) b=Rsin(P)
则题目(a+bi)(c+di)=(R1cos(P1)+R1sin(P1)i)*(R2cos(P2)+R2sin(P2)i)
则实部R1cos(P1)*R2cos(P2)-R1sin(P1)*R2sin(P2)
=R1R2cos(P1)cos(P2)-R1R2sin(P1)sin(P2)这一步
=R1R2(cos(P1)cos(P2)-sin(P1)sin(P2))
=R1R2cos(P1+P1)
if (A + 0.005 >= 0 && A < 0)
printf("0.00");
是因为实部为小数,并且小数为-0.004、-0.003、-0.002、-0.001,
则-0.004+0.005=0.001,保留两位小数为0.00