力扣43. 字符串相乘

Problem: 43. 字符串相乘

文章目录

题目描述

思路及解法

1.初始化和结果数组:

1.1.获取 num1 和 num2 的长度。

1.2.初始化一个 int 数组 res,长度为 len1 + len2,用于存储中间计算结果。因为两个数相乘的结果最多是 len1 + len2 位。
2.逐位相乘:
2.1.从两个字符串的最低位(个位)开始逐位相乘。

2.2.计算乘积 mul,对应到结果数组的两个位置 p1 和 p2。p1 是进位位置,p2 是当前位位置。

2.3.将乘积加到 res[p2],同时处理进位。
3.处理结果数组前导零:遍历 res 数组,跳过前导零,找到第一个非零元素的位置。
4.构建最终结果字符串:
4.1.使用 StringBuilder 将结果数组中的数字逐个转换为字符并拼接成字符串。

4.2.如果结果字符串为空,返回 "0";否则返回拼接好的字符串。

复杂度

时间复杂度:

O ( M × N ) O(M \times N) O(M×N);其中 M M M是数组num1的长度, N N N是数组num2的长度

空间复杂度:

O ( M + N ) O(M + N) O(M + N)

Code

java 复制代码
class Solution {
    /**
     * Multiply Strings
     *
     * @param num1 Given array
     * @param num2 Given array
     * @return String
     */
    public String multiply(String num1, String num2) {
        int len1 = num1.length();
        int len2 = num2.length();
        // The result has a maximum of len1 + len2 bits
        int[] res = new int[len1 + len2];
        // Multiply digit by digit starting from the ones digit
        for (int i = len1 - 1; i >= 0; --i) {
            for (int j = len2 - 1; j >= 0; --j) {
                int mul = (num1.charAt(i) - '0') * (num2.charAt(j) - '0');
                // The product is in the index position of res
                int p1 = i + j;
                int p2 = i + j + 1;
                // Overlay to res
                int sum = mul + res[p2];
                res[p2] = sum % 10;
                res[p1] += sum / 10;
            }
        }
        // Result prefix possible stored 0(unused bits)
        int i = 0;
        while (i < res.length && res[i] == 0) {
            i++;
        }
        // Converts the result to a string
        StringBuilder str = new StringBuilder();
        for (; i < res.length; ++i) {
            str.append((char) ('0' + res[i]));
        }
        return str.length() == 0 ? "0" : str.toString();
    }
}
相关推荐
小开不是小可爱9 分钟前
leetcode_383. 赎金信_java
java·数据结构·算法·leetcode
√尖尖角↑4 小时前
力扣——【1991. 找到数组的中间位置】
算法·蓝桥杯
Allen Wurlitzer4 小时前
算法刷题记录——LeetCode篇(1.8) [第71~80题](持续更新)
算法·leetcode·职场和发展
百锦再6 小时前
五种常用的web加密算法
前端·算法·前端框架·web·加密·机密
碳基学AI6 小时前
北京大学DeepSeek内部研讨系列:AI在新媒体运营中的应用与挑战|122页PPT下载方法
大数据·人工智能·python·算法·ai·新媒体运营·产品运营
独家回忆3647 小时前
每日算法-250410
算法
袖清暮雨7 小时前
Python刷题笔记
笔记·python·算法
熬夜造bug8 小时前
LeetCode Hot100 刷题笔记(1)—— 哈希、双指针、滑动窗口
笔记·leetcode·hot100
风掣长空8 小时前
八大排序——c++版
数据结构·算法·排序算法
流星白龙9 小时前
【C++算法】50.分治_归并_翻转对
c++·算法