Java实现/python LeetCode 537.复数乘法

编程入门 行业动态 更新时间:2024-10-10 21:25:36

Java实现/python  LeetCode 537.<a href=https://www.elefans.com/category/jswz/34/1747193.html style=复数乘法"/>

Java实现/python LeetCode 537.复数乘法

给定两个表示复数的字符串。

返回表示它们乘积的字符串。注意,根据定义 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] 之间。输出也应当符合这种形式。

来源:力扣(LeetCode)
链接:
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

注:
String a = “1+2i”;
String b = “3+4i”;
ai = 1;
bi = 2;
ci = 3;
di = 4;
num1 = aici + bidi*(-1);
num2 = aidi + cibi
String ans = num1 + num2i;

class Solution {public String complexNumberMultiply(String a, String b) {int mark = 0;String[] str1 = a.split("\\+");String[] str2 = b.split("\\+");int ai = Integer.parseInt(str1[0]);int ci = Integer.parseInt(str2[0]);int bi = Integer.parseInt(str1[1].substring(0, str1[1].length()-1));int di = Integer.parseInt(str2[1].substring(0, str2[1].length()-1));int num1 = ai*ci + bi*di*(-1);int num2 = ai*di + ci*bi;String ans = num1 + "+" + num2 + "i";return ans;}
}

python

class Solution:def complexNumberMultiply(self, a: str, b: str) -> str:str1 = a.split('+')str2 = b.split('+')num1 = int(str1[0])*int(str2[0]) - int(str1[1][:-1])*int(str2[1][:-1])num2 = int(str1[0])*int(str2[1][:-1]) + int(str1[1][:-1])*int(str2[0])ans =str(num1) + '+' + str(num2) + 'i'return ans

更多推荐

Java实现/python LeetCode 537.复数乘法

本文发布于:2024-03-06 19:41:01,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1716205.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:复数   乘法   python   Java   LeetCode

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!