标签:map %. 1.0 四则运算 36 1fi printf PAT 2.0
本题要求编写程序,计算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> main() { float a,b,c,d; scanf("%f%f%f%f",&a,&b,&c,&d); int i; char map[4]={'+','-','*','/'}; for(i=0;i<4;i++) { float x,y; switch(i) { case 0:x=a+c;y=b+d;break; case 1:x=a-c;y=b-d;break; case 2:x=a*c-b*d;y=b*c+a*d;break; case 3:x=(a*c+b*d)/(c*c+d*d);y=(b*c-a*d)/(c*c+d*d);break; } if(b>=0&&d>=0) printf("(%.1f+%.1fi) %c (%.1f+%.1fi) = ",a,b,map[i],c,d); else if(b>=0&&d<0) printf("(%.1f+%.1fi) %c (%.1f%.1fi) = ",a,b,map[i],c,d); else if(b<0&&d>=0) printf("(%.1f%.1fi) %c (%.1f+%.1fi) = ",a,b,map[i],c,d); else printf("(%.1f%.1fi) %c (%.1f%.1fi) = ",a,b,map[i],c,d); if(fabs(x)<0.1&&fabs(y)<0.1){printf("0.0\n");continue;} int flag=0; if(fabs(x)>=0.1){printf("%.1f",x);flag=1;} if(fabs(y)>=0.1) { if(flag&&y>0.0)printf("+%.1fi",y); else printf("%.1fi",y); } printf("\n"); } }
标签:map,%.,1.0,四则运算,36,1fi,printf,PAT,2.0 来源: https://www.cnblogs.com/yunners/p/12488298.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。