标签:
设计复数库,实现基本的复数加减乘除运算。
输入时只需分别键入实部和虚部,以空格分割,两个复数之间用运算符分隔;输出时按a+bi的格式在屏幕上打印结果。参加样例输入和样例输出。
注意考虑特殊情况,无法计算时输出字符串"error"。
样例输入
2 4 * -3 2
样例输出
-14-8i
样例输入
3 -2 + -1 3
样例输出
2+1i
解题分析:
复数运算法则
http://baike.baidu.com/link?url=i7MKOzPCWS-sN0-NEuy_4kVejT1TZzpED8qOLDJnDUuwj91OAGRj_zA-BrvRD0VboeKHaMFve_xmajcbLC9Ada
代码:
#include<cstdio>
#include<cstdlib>
#include<cstring>
using namespace std;
int main()
{
double a,b,c,d,n,m;
char ch;
scanf("%lf %lf %c %lf %lf",&a,&b,&ch,&c,&d);
if(ch==‘+‘){
n=a+c;m=b+d;
if(m==0)printf("%g\n",n);
else if(m<0&&n!=0)printf("%g%gi\n",n,m);
else if(m>0&&n!=0)printf("%g+%gi\n",n,m);
else if(n==0&&m!=0)printf("%gi\n",m);
}
else if(ch==‘-‘){
n=a-c;m=b-d;
if(m==0)printf("%g\n",n);
else if(m<0&&n!=0)printf("%g%gi\n",n,m);
else if(m>0&&n!=0)printf("%g+%gi\n",n,m);
else if(n==0&&m!=0)printf("%gi\n",m);
}
else if(ch==‘*‘){
n=a*c+b*d*-1;m=a*d+b*c;
if(m==0)printf("%g\n",n);
else if(m<0&&n!=0)printf("%g%gi\n",n,m);
else if(m>0&&n!=0)printf("%g+%gi\n",n,m);
else if(n==0&&m!=0)printf("%gi\n",m);
}
else if(ch==‘/‘){
double ans=c*c+d*d;
if(ans==0)printf("error\n");
else {
d=d*-1;
a=a/ans;b=b/ans;
n=a*c+b*d*-1;m=a*d+b*c;
if(m==0)printf("%g\n",n);
else if(m<0&&n!=0)printf("%g%gi\n",n,m);
else if(m>0&&n!=0)printf("%g+%gi\n",n,m);
else if(n==0&&m!=0)printf("%gi\n",m);
}
}
return 0;
}
6-17复数四则运算 --- 蓝桥杯
标签:
原文地址:http://blog.csdn.net/u012965373/article/details/44957757