输入格式:
输入在一行中按照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
首先我们来看看复数的除法是怎么运算的:
然后是复数的乘法运算结果:(ac-bd)+(bc+ad)i
我的代码:
struct plural //用结构体来储存复数
{
double shibu;//实部
double xubu;//虚部
}pl[2];//定义一个结构体数组来储存两个复数
struct result
{
double shibu;
double xubu;
}re[4];//定义一个结构体数组来储存四个结果复数
void resultPrint( struct plural * pl ,struct result * x, char ch);//函数用作显示功能 避免主函数里冗长的代码段
int main()
{
int i;
for(i=0;i<2;i++)
{
scanf("%lf",&pl[i].shibu);
scanf("%lf",&pl[i].xubu);
}//依次输入第一二个复数的实部和虚部
/*加法部分,复数的加减法都比较简单,实部和实部相加,虚部和虚部相加*/
re[0].shibu=pl[0].shibu+pl[1].shibu;
re[0].xubu=pl[0].xubu+pl[1].xubu;
resultPrint(pl,&re[0],'+');//将运算复数的结构体数组的首地址(pl),结果复数结构体的地址,和算术符号传给函数
printf("\n");
/*减法部分*/
re[1].shibu=pl[0].shibu-pl[1].shibu;
re[1].xubu=pl[0].xubu-pl[1].xubu;
resultPrint(pl,&re[1],'-');
putchar('\n');
/*乘法部分*/
re[2].shibu=( (pl[0].shibu * pl[1].shibu) - (pl[0].xubu * pl[1].xubu) );
re[2].xubu=( (pl[0].shibu * pl[1].xubu) +(pl[1].shibu * pl[0].xubu) );
resultPrint(pl,&re[2],'*');
putchar('\n');
/*除法部分 这里需要注意:因为存在纯实数运算 当纯实数运算时 结果的实部计算时不能用对应公式 否则会出错 直接用被除数的实部/除数的实部即可*/
if(pl[0].xubu==0&&pl[1].xubu==0)//当两个数都是纯实数的时候
re[3].shibu=pl[0].shibu/pl[1].shibu;//直接相除
else re[3].shibu=( pl[0].shibu *pl[1].shibu + pl[0].xubu*pl[1].xubu ) / ( pow(pl[0].shibu,2) +pow(pl[1].xubu,2) ) ;//否则就用对应公式
re[3].xubu=( pl[0].xubu * pl[1].shibu - pl[0].shibu*pl[1].xubu ) / ( pow(pl[0].shibu,2) +pow(pl[1].xubu,2) ) ;
resultPrint(pl,&re[3],'/');
putchar('\n');
}
void resultPrint( struct plural * x ,struct result * y, char ch)//x,y是结构体类型指针 分别指向运算复数 和 结果复数
{
printf("(%.1f%+-.1fi) %c (%.1f%+-.1fi)",x[0].shibu,x[0].xubu, ch, x[1].shibu,x[1].xubu);//查阅资料得知 用%+-d这样的形式可以输出数字前的正负号 省去了一大段代码
if(fabs(y->shibu)<0.05&&fabs(y->xubu)<0.05)
printf(" = 0.0");//当实部 虚部绝对值均小于0.05时 全都舍去 结果为0.0
else if( fabs(y->shibu)<0.05&&fabs(y->xubu)>0.05)//实部小于0.05 虚部大于0.05时 仅保留虚部
printf(" = %.1lfi",y->xubu);
else if( fabs(y->xubu)<0.05&&fabs(y->shibu)>0.05)
printf(" = %.1lf",y->shibu);
else printf(" = %.1lf%+-.1lfi",y->shibu,y->xubu);//不属于以上三种情况时 直接输出实部和虚部
}