给定两个表示复数的字符串。
返回表示它们乘积的字符串。注意,根据定义 i2 = -1 。
示例 1:
输入: "1+1i", "1+1i"
输出: "0+2i"
解释: (1 + i) * (1 + i) = 1 + i2 + 2 * i = 2i ,你需要将它转换为 0+2i 的形式。
示例 2:
输入: "1+-1i", "1+-1i"
输出: "0+-2i"
解释: (1 - i) * (1 - i) = 1 + i2 - 2 * i = -2i ,你需要将它转换为 0+-2i 的形式。
注意:
输入字符串不包含额外的空格。
输入字符串将以 a+bi 的形式给出,其中整数 a 和 b 的范围均在 [-100, 100] 之间。输出也应当符合这种形式。
===========================================================================================================================================================================================================
分析:
(a+bi)*(c+di)=(ac+adi)+(bci+dbi*i)=(ac-bd)+(ad+bc)i
char * complexNumberMultiply(char * x, char * y){
int a = 0;
int b = 0;
int c = 0;
int d = 0;
// (a+bi)*(c+di)=(ac+adi)+(bci+dbi*i)=(ac-bd)+(ad+bc)i
char* res = (char*)malloc(sizeof(char)*100);
sscanf(x,"%d+%d",&a,&b);
sscanf(y,"%d+%d",&c,&d);
sprintf(res,"%d+%di",(a*c-b*d),(a*d+b*c));
return res;
}
参考:https://leetcode-cn.com/problems/complex-number-multiplication