设计复数库,实现基本的复数加减乘除运算。
输入时只需分别键入实部和虚部,以空格分割,两个复数之间用运算符分隔;输出时按a+bi的格式在屏幕上打印结果。参加样例输入和样例输出。
注意考虑特殊情况,无法计算时输出字符串"error"。
样例输入
2 4 * -3 2
样例输出
-14-8i
样例输入
3 -2 + -1 3
样例输出
2+1i
复数四则运算
加法法则
复数的加法按照以下规定的法则进行:设z1=a+bi,z2=c+di是任意两个复数,
则它们的和是 (a+bi)+(c+di)=(a+c)+(b+d)i。
两个复数的和依然是复数,它的实部是原来两个复数实部的和,它的虚部是原来两个虚部的和。
复数的加法满足交换律和结合律,
即对任意复数z1,z2,z3,有: z1+z2=z2+z1;(z1+z2)+z3=z1+(z2+z3)。
减法法则
复数的减法按照以下规定的法则进行:设z1=a+bi,z2=c+di是任意两个复数,
则它们的差是 (a+bi)-(c+di)=(a-c)+(b-d)i。
两个复数的差依然是复数,它的实部是原来两个复数实部的差,它的虚部是原来两个虚部的差。
乘除法
编辑
乘法法则
规定复数的乘法按照以下的法则进行:
设z1=a+bi,z2=c+di(a、b、c、d∈R)是任意两个复数,那么它们的积(a+bi)(c+di)=(ac-bd)+(bc+ad)i。
其实就是把两个复数相乘,类似两个多项式相乘,展开得: ac+adi+bci+bdi2,因为i2=-1,所以结果是(ac-bd)+(bc+ad)i 。两个复数的积仍然是一个复数。
在极坐标下,复数可用模长r与幅角θ表示为(r,θ)。对于复数a+bi,r=√(a²+b²),θ=arctan(b/a)。此时,复数相乘表现为幅角相加,模长相乘。
除法法则
复数除法定义:满足(c+di)(x+yi)=(a+bi)的复数x+yi(x,y∈R)叫复数a+bi除以复数c+di的商。
运算方法:可以把除法换算成乘法做,在分子分母同时乘上分母的共轭.。所谓共轭你可以理解为加减号的变换,互为共轭的两个复数相乘是个实常数。
除法运算规则:
①设复数a+bi(a,b∈R),除以c+di(c,d∈R),其商为x+yi(x,y∈R),
即(a+bi)÷(c+di)=x+yi
∵(x+yi)(c+di)=(cx-dy)+(dx+cy)i
∴(cx-dy)+(dx+cy)i=a+bi
由复数相等定义可知 cx-dy=a dx+cy=b
解这个方程组,得 x=(ac+bd)/(c2+d2) y=(bc-ad)/(c2+d2)
于是有:(a+bi)/(c+di)=(ac+bd)/(c2+d2) +((bc-ad)/(c2+d2))i
②利用共轭复数将分母实数化得(见右图):
点评:①是常规方法;②是利用初中我们学习的化简无理分式时,都是采用的分母有理化思想方法,而复数c+di与复数c-di,相当于我们初中学习的 的对偶式,它们之积为1是有理数,而(c+di)·(c-di)=c2+d2是正实数.所以可以分母实数化。把这种方法叫做分母实数化法。
另外,由上述乘法法则可得另一计算方法,即幅角相减,模长相除。
作者注释:之前有个问题解决不了:怎么视情况保留小数点后一位、当计算出的小数位为0时则不保留小数。所以有个测试点一直不过。但是,后来查阅后学会用%g——%g用来输出实数,根据数值大小,自动选f或e格式不输出无意义的零。
C程序代码
#include <iostream>
#include <stdio.h>
#include <math.h>
#include <stdlib.h>
#define N 1e-6
int main( )
{
float a,b,c,d,x,y;
char ch;
while(scanf("%f%f %c%f%f",&a,&b,&ch,&c,&d)!=EOF)//循环输入
{
if(ch=='+')//加法
{
x=a+c;
y=b+d;
}
else if(ch=='-')//减法
{
x=a-c;
y=b-d;
}
else if(ch=='*')//乘法
{
x=a*c-b*d;
y=b*c+a*d;
}
else if(ch=='/')//除法
{
if(c==0&&d==0)//除数不能为0
{
printf("error");
continue;
}
x=(a*c+b*d)/(c*c+d*d);
y=(b*c-a*d)/(c*c+d*d);
}
if(y>=N)//浮点型比较大小的方式
printf("%g+%gi",x,y);//正数前面自身没有‘+’
else if(y<N)
printf("%g%gi",x,y);//负数前面自身有‘-’
}
return 0;
}
C++代码:
C++能自动处理数据类型,用C++更好
#include<iostream>
using namespace std;
void add(double a,double b,double c,double d)
{
cout<<a+c;
if(b+d>=0)
cout<<"+";
cout<<b+d;
cout<<'i'<<endl;
}
void sub(double a,double b,double c,double d)
{
cout<<a-c;
if(b-d>=0)
cout<<"+";
cout<<b-d;
cout<<'i'<<endl;
}
void mul(double a,double b,double c,double d)
{
cout<<a*c-b*d;
if(a*d+b*c>=0)
cout<<"+";
cout<<a*d+b*c;
cout<<'i'<<endl;
}
void div(double a,double b,double c,double d)
{
if(c==0&&d==0)
{
cout<<"error"<<endl;
return;
}
cout<<(a*c+b*d)/(c*c+d*d);
if(b*c-a*d>=0)
cout<<"+";
cout<<(b*c-a*d)/(c*c+d*d);
cout<<'i'<<endl;
}
int main()
{
char op;
double a,b,c,d;
cin>>a>>b>>op>>c>>d;
if(op=='+')
add(a,b,c,d);
if(op=='-')
sub(a,b,c,d);
if(op=='*')
mul(a,b,c,d);
if(op=='/')
div(a,b,c,d);
return 0;
}