C语言函数——复数四则运算
本题要求编写程序,计算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<stdio.h>
#include<math.h>
void add (double a,double b,double c,double d);
void reduce (double a,double b,double c,double d);
void cheng (double a,double b,double c,double d);
void chu (double a,double b,double c,double d);
int main ()
{
double a,b,c,d;
scanf("%lf%lf%lf%lf",&a,&b,&c,&d);
add(a,b,c,d);
reduce(a,b,c,d);
cheng(a,b,c,d);
chu(a,b,c,d);
return 0;
}
void add (double a,double b,double c,double d)
{
if(b>=0) printf("(%.1f+%.1fi) + (",a,b);
else printf("(%.1f%.1fi) + (",a,b);
if(d>=0) printf("%.1f+%.1fi) = ",c,d);
else printf("%.1f-%.1fi) = ",c,d);
if(fabs(a+c)<0.05&&fabs(b+d)<0.05) printf("0.0\n");
else if(fabs(a+c)<0.05&&fabs(b+d)>=0.05) printf("%.1fi\n",b+d);
else if(fabs(a+c)>=0.05&&fabs(b+d)<0.05) printf("%.1f\n",a+c);
else {
if(fabs(b+d)>0.0) printf("%.1f+%.1fi\n",a+c,b+d);
else printf("%.1f%.1fi\n",a+c,b+d);
}
return;
}
void reduce (double a,double b,double c,double d)
{
if(b>=0) printf("(%.1f+%.1fi) - (",a,b);
else printf("(%.1f%.1fi) - (",a,b);
if(d>=0) printf("%.1f+%.1fi) = ",c,d);
else printf("%.1f-%.1fi) = ",c,d);
if(fabs(a-c)<0.05&&fabs(b-d)<0.05) printf("0.0\n");
else if(fabs(a-c)<0.05&&fabs(b-d)>=0.05) printf("%.1fi\n",b-d);
else if(fabs(a-c)>=0.05&&fabs(b-d)<0.05) printf("%.1f\n",a-c);
else {
if(b-d>0) printf("%.1f+%.1fi\n",a-c,b-d);
else printf("%.1f%.1fi\n",a-c,b-d);
}
return;
}
void cheng (double a,double b,double c,double d)
{
if(b>=0) printf("(%.1f+%.1fi) * (",a,b);
else printf("(%.1f%.1fi) * (",a,b);
if(d>=0) printf("%.1f+%.1fi) = ",c,d);
else printf("%.1f-%.1fi) = ",c,d);
if(fabs(a*c-b*d)<0.05&&fabs(a*d+c*b)<0.05) printf("0.0\n");
else if(fabs(a*c-b*d)<0.05&&fabs(a*d+c*b)>=0.05) printf("%.1fi\n",a*d+b*c);
else if(fabs(a*c-b*d)>=0.05&&fabs(a*d+c*b)<0.05) printf("%.1f\n",a*c-b*d);
else {
if(a*d+c*b<0) printf("%.1f%.1fi\n",a*c-b*d,a*d+b*c);
else printf("%.1f+%.1fi\n",a*c-b*d,a*d+c*b);
}
return;
}
void chu (double a,double b,double c,double d)
{
if(b>=0) printf("(%.1f+%.1fi) / (",a,b);
else printf("(%.1f%.1fi) / (",a,b);
if(d>=0) printf("%.1f+%.1fi) = ",c,d);
else printf("%.1f-%.1fi) = ",c,d);
if(fabs((a*c+b*d)/(c*c+d*d))<0.05&&fabs((c*b-a*d)/(c*c+d*d))<0.05) printf("0.0\n");
else if(fabs((a*c+b*d)/(c*c+d*d))<0.05&&fabs((c*b-a*d)/(c*c+d*d))>=0.05) printf("%.1fi\n",(c*b-a*d)/(c*c+d*d));
else if(fabs((a*c+b*d)/(c*c+d*d))>=0.05&&fabs((c*b-a*d)/(c*c+d*d))<0.05) printf("%.1f\n",(a*c+b*d)/(c*c+d*d));
else {
if(c*b-a*d<0) printf("%.1f%.1fi\n",(a*c+b*d)/(c*c+d*d),((c*b-a*d)/(c*c+d*d)));
else printf("%.1f+%.1fi\n",(a*c+b*d)/(c*c+d*d),((c*b-a*d)/(c*c+d*d)) );
}
return;
}