试题 算法训练 P1103
资源限制
时间限制:1.0s 内存限制:256.0MB
问题描述
编程实现两个复数的运算。设有两个复数 和 ,则他们的运算公式为:
要求:(1)定义一个结构体类型来描述复数。
(2)复数之间的加法、减法、乘法和除法分别用不用的函数来实现。
(3)必须使用结构体指针的方法把函数的计算结果返回。
说明:用户输入:运算符号(+,-,*,/) a b c d.
输出:a+bi,输出时不管a,b是小于0或等于0都按该格式输出,输出时a,b都保留两位。
样例输入
- 2.5 3.6 1.5 4.9
样例输出
1.00+-1.30i
相关公式
乘法公式:
(a+bi)(c+di)=(ac-bd)+(bc+ad)i
除法公式:
代码
#include<stdio.h>
struct in{
float a;
float b;
};
int main(){
struct in n[3];
char a;
scanf("%c%f%f%f%f",&a,&n[0].a,&n[0].b,&n[1].a,&n[1].b);//分别代表a,b,c,d
if(a=='+'){
n[2].a=n[0].a+n[1].a;
n[2].b=n[0].b+n[1].b;
}
else if(a=='-'){
n[2].a=n[0].a-n[1].a;
n[2].b=n[0].b-n[1].b;
}
else if(a=='*'){
n[2].a=n[0].a*n[1].a-n[0].b*n[1].b;
n[2].b=n[0].a*n[1].b+n[0].b*n[1].a;
}
else{
n[2].a=(n[0].a*n[1].a+n[0].b*n[1].b)/(n[1].a*n[1].a+n[1].b*n[1].b);
n[2].b=(n[0].b*n[1].a-n[0].a*n[1].b)/(n[1].a*n[1].a+n[1].b*n[1].b);
}
printf("%.2f+%.2fi",n[2].a,n[2].b);
return 0;
}