leetcode_43.字符串相乘

devtools/2024/9/24 10:15:24/

43. 字符串相乘

题目描述:给定两个以字符串形式表示的非负整数 num1 和 num2,返回 num1 和 num2 的乘积,它们的乘积也表示为字符串形式。

注意:不能使用任何内置的 BigInteger 库或直接将输入转换为整数。

示例 1:

输入: num1 = "2", num2 = "3"
输出: "6"

示例 2:

输入: num1 = "123", num2 = "456"
输出: "56088"

提示:

  • 1 <= num1.length, num2.length <= 200
  • num1 和 num2 只能由数字组成。
  • num1 和 num2 都不包含任何前导零,除了数字0本身。
 代码思路:
  1. 代码获取了输入字符串的长度,并创建了一个数组 temp 用于存储中间结果,其长度为 len1 + len2 - 1。这是因为两个长度分别为 len1len2 的数字相乘的结果的最大位数为 len1 + len2,但是最高位不会在中间结果中出现。

  2. 接着,两层循环遍历每一位数字,并将它们两两的乘积加到 temp 数组的对应位置上。

  3. 然后,通过一个循环来处理进位,将 temp 数组中的每一位进行进位处理,确保每一位都在 0 到 9 之间。

  4. 最后,代码使用 StringBuilder 将 temp 数组中的每一位数字转换为字符串,并返回结果。

示例:

class Solution {public String multiply(String num1, String num2) {if (num1.equals("0") || num2.equals("0")) return "0";int len1 = num1.length();int len2 = num2.length();int[] temp = new int[len1 + len2 - 1];for (int i = 0; i < len1; i++) {for (int j = 0; j < len2; j++) {temp[i + j] += (num1.charAt(i) - '0') * (num2.charAt(j) - '0');}}for (int i = len1 + len2 - 2; i > 0; i--) {temp[i - 1] += temp[i] / 10;temp[i] %= 10;}StringBuilder sb = new StringBuilder();for (int x : temp) sb.append(x);return sb.toString();}
}


http://www.ppmy.cn/devtools/31848.html

相关文章

docker搭建redis集群三主三从

为什么需要做分布式redis 水平扩展&#xff1a; 随着业务的发展&#xff0c;单机Redis可能无法满足日益增长的数据存储和访问需求。分布式Redis可以通过将数据分散到多个节点上来实现水平扩展&#xff0c;提高存储容量和处理能力。高可用性&#xff1a; 单点故障是任何系统的一…

2024五一杯数学建模C题思路分享 - 煤矿深部开采冲击地压危险预测

文章目录 1 赛题选题分析 2 解题思路2.1 问题重述2.2 第一问完整思路2.2 二、三问思路更新 3 最新思路更新 1 赛题 C题 煤矿深部开采冲击地压危险预测 煤炭是中国的主要能源和重要的工业原料。然而&#xff0c;随着开采深度的增加&#xff0c;地应力增大&#xff0c;井下煤岩动…

MATLAB中功率谱密度计算pwelch函数使用详解

MATLAB中功率谱密度计算pwelch函数使用详解 目录 前言 一、pwelch函数简介 二、pwelch函数参数说明 三、pxx pwelch(x)示例 四、[pxx,f]pwelch(x,window,noverlap,nfft,fs)示例 四、[pxx,f] pwelch(x,window,noverlap,nfft,fs,freqrange,spectrumtype)示例 五、多通道功…

pinia学习1:pinia的介绍与使用方法

Pinia是一个专门为Vue.js设计的状态管理库&#xff0c;它的主要目标是提供一种更加简单、直观且可扩展的方式来管理和访问应用程序的状态。与Vuex相比&#xff0c;Pinia更加轻量级&#xff0c;并且与Vue 3的Composition API完美结合&#xff0c;使得状态管理变得更加灵活和高效…

c语言题目

一些关于c语言的题目 文章目录 一、计算程序输出二、以下程序运行时&#xff0c;若输入1abcedf2df<回车>输出结果是将flag的第二个bit置0结构体大小下列C程序执行后c输出结果为&#xff08;&#xff09;设有定义char *p[]{"Shanghai","Beijing",&quo…

【JavaEE】JavaScript

文章目录 一、初识 JavaScript1、JavaScript 是什么 二、语法1、变量的使用 一、初识 JavaScript 1、JavaScript 是什么 JavaScript (简称 JS) 是世界上最流行的编程语言之一 是一个脚本语言, 通过解释器运行 主要在客户端(浏览器)上运行, 现在也可以基于 node.js 在服务器端…

Python基础学习之os模块

在Python编程的世界中&#xff0c;内置库为我们提供了丰富的功能和工具&#xff0c;使我们能够轻松处理各种任务。其中&#xff0c;os模块是一个极其重要且常用的库&#xff0c;它提供了与操作系统交互的接口。本文将带您一起探索os模块的一些常用功能。 1. os模块简介 os模块…

Python系列一之excel的读取

这里我常用的 python 对于 excel 的读取库有两个&#xff0c;一个是 xlsxwriter 用于操作 excel 的写入&#xff0c;一个是 xlrd 用于 excel 文件的读取。 使用的库的版本如下&#xff1a; xlsx1.2.6xlrd1.1.0 xlsxwriter 写入 excel 新建一个 excel import xlsxwriterpat…