537. 复数乘法

537. 复数乘法

题目

难度:中等
可以用字符串表示,遵循 “实部+虚部i” 的形式,并满足下述条件:
(1)实部 是一个整数,取值范围是 [-100, 100]
(2)虚部 也是一个整数,取值范围是 [-100, 100]
(3)i2 == -1
给你两个字符串表示的复数 num1 和 num2 ,请你遵循复数表示形式,返回表示它们乘积的字符串。

示例 1:
输入:num1 = “1+1i”, num2 = “1+1i”
输出:“0+2i”
解释:(1 + i) * (1 + i) = 1 + i2 + 2 * i = 2i ,你需要将它转换为 0+2i 的形式。

示例 2:
输入:num1 = “1±1i”, num2 = “1±1i”
输出:“0±2i”
解释:(1 - i) * (1 - i) = 1 + i2 - 2 * i = -2i ,你需要将它转换为 0±2i 的形式。

提示:
num1 和 num2 都是有效的复数表示。

题解

1、简单算术乘法
分别计算实部 * 实部,实部 * 虚部,虚部 * 虚部 的结果

2、将乘法结果根据要求规则修改成复数形式

代码

class Solution {
    /**
     * 复数乘法
     * 1、简单算术乘法
     * 2、将乘法结果通过规则进行修改成复数形式
     *
     * @param num1 复数1
     * @param num2 复数2
     * @return 乘结果
     */
    public String complexNumberMultiply(String num1, String num2) {
        // 例子: (1 + -1i) * (1 + -1i) => 1 + 1 * (-1i) + (-1i) * 1 + (-1i) * (-1i)
        // 将实部和虚部分开
        String[] split1 = num1.split("\\+");
        String[] split2 = num2.split("\\+");

        // 实部乘积结果
        final int act1 = Integer.parseInt(split1[0]); // 1
        final int act2 = Integer.parseInt(split2[0]); // 1
        int actMultiply = act1 * act2;

        // 将虚部整数和i分开
        int xuInt1 = Integer.parseInt(split1[1].substring(0, split1[1].length() - 1)); // -1
        int xuInt2 = Integer.parseInt(split2[1].substring(0, split2[1].length() - 1)); // -1

        // 虚部乘积(结果带i的)
        int xuIntMultiplyI = act1 * xuInt2 + act2 * xuInt1;

        // 虚部乘积(结果 i^2 的)
        int xuIntMultiplyI2 = xuInt1 * xuInt2 * -1;

        // 计算结果
        return (actMultiply + xuIntMultiplyI2) + "+" + xuIntMultiplyI + "i";
    }
}

考点

1、正则表达式转义
比如以 ‘+’ 进行分割,需要转义 ‘\+’(其中第一个\是对第二个\的转义)
2、字符串和整数间转换

上一篇:【每日一题】力扣455:分发饼干


下一篇:C基础篇--第一章