算法-字符串-43.字符串相乘

一、题目

二、思路解析

1.思路:

1.双重for循环,倒序依次相乘

2.在倒序处理进位问题

3.最后返回参数的类型是string,用StringBuilder拼接,再转换为字符串

2.常用方法:

1.equals,比较对象内容是否一致

java 复制代码
"0".equals(num1);

2.append(),拼接字符

java 复制代码
sb.append(res[index]);

3.toString(),转字符串

java 复制代码
sb.toString();

3.核心逻辑:

1.处理特殊情况,当两个字符串有其中一个为"0",即返回结果值为"0"

java 复制代码
if("0".equals(num1)||"0".equals(num2)) return "0";

2.定义一个整型数组res来存储每一个位数于位数的乘积值,无需关注是否进位问题

java 复制代码
int[]res=new int[num1.length()+num2.length()];

for(int i=num1.length()-1;i>=0;i--){
    int temp1=num1.charAt(i)-'0';

    for(int j=num2.length()-1;j>=0;j--){
     int temp2=num2.charAt(j)-'0';
     res[i+j+1]+=temp1+temp2;
}
}
  1. 处理进位问题
java 复制代码
for(int i=res.length-1;i>0;i--){
    res[i-1]+=res/10;
    res[i]=res[i]%10;
}

4.拼接字符串

√.注意事项:两数相乘,最后的结果位数范围是不超过两数位数相加,同时也不会小于 两数位数相加-1;故需要判断首字符是否为0,才好决定从哪一位开始拼接

java 复制代码
int index=res[0]==0?1:0;
        StringBuilder sb=new StringBuilder();
        for(int i=index;i<res.length;i++){
            sb.append(res[i]);
        }
        return sb.toString();

三、代码实现

java 复制代码
class Solution {
    public String multiply(String num1, String num2) {
        if("0".equals(num1)||"0".equals(num2)){
            return "0";
        }

        int size1=num1.length();
        int size2=num2.length();
        int[]res=new int[size1+size2];

        for(int i=size1-1;i>=0;i--){
            int t1=num1.charAt(i)-'0';
            for(int j=size2-1;j>=0;j--){
                int t2=num2.charAt(j)-'0';
                res[i+j+1]+=t1*t2;
            }
        }
        for(int i=res.length-1;i>0;i--){
            res[i-1]+=res[i]/10;
            res[i]=res[i]%10;
        }
        int start=res[0]==0?1:0;
        StringBuilder sb=new StringBuilder();
        for(int i=start;i<res.length;i++){
            sb.append(res[i]);
        }
        return sb.toString();
    }
}
相关推荐
小碗羊肉2 分钟前
【从零开始学Java | 第二十八篇】可变参数
java·开发语言
Java成神之路-2 分钟前
Spring AOP 核心进阶:切入点表达式 + 通知类型 + 环绕通知避坑指南(Spring系列8)
java·后端·spring
weitingfu12 分钟前
Excel VBA 入门到精通(二):变量、数据类型与运算符
java·大数据·开发语言·学习·microsoft·excel·vba
光电笑映15 分钟前
STL 源码解密:unordered 系列容器的底层复用与哈希策略
算法·哈希算法·散列表
foundbug99922 分钟前
无人机离散系统模型预测控制(MPC)MATLAB实现
开发语言·matlab·无人机
6Hzlia26 分钟前
【Hot 100 刷题计划】 LeetCode 215. 数组中的第K个最大元素 | C++ 快速选择与堆排序题解
c++·算法·leetcode
小白菜又菜26 分钟前
Leetcode 3070. Count Submatrices with Top-Left Element and Sum Less Than k
算法·leetcode·职场和发展
某人辛木26 分钟前
Maven一步到位
java·maven
爱写代码的小朋友31 分钟前
使用 Nuitka 打包 Python 应用:从入门到进阶
开发语言·python
一条咸鱼_SaltyFish36 分钟前
DDD 架构重构实践:AI Skills 如何赋能DDD设计与重构
java·人工智能·ai·重构·架构·ddd·领域驱动设计