力扣43. 字符串相乘

embedded/2024/11/15 0:41:53/

Problem: 43. 字符串相乘

文章目录

  • 题目描述
  • 思路及解法
  • 复杂度
  • Code

题目描述

在这里插入图片描述

思路及解法

1.初始化和结果数组:

1.1.获取 num1 和 num2 的长度。
1.2.初始化一个 int 数组 res,长度为 len1 + len2,用于存储中间计算结果。因为两个数相乘的结果最多是 len1 + len2 位。

2.逐位相乘:

2.1.从两个字符串的最低位(个位)开始逐位相乘。
2.2.计算乘积 mul,对应到结果数组的两个位置 p1 和 p2。p1 是进位位置,p2 是当前位位置。
image.png
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

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 bitsint[] res = new int[len1 + len2];// Multiply digit by digit starting from the ones digitfor (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 resint p1 = i + j;int p2 = i + j + 1;// Overlay to resint 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 stringStringBuilder str = new StringBuilder();for (; i < res.length; ++i) {str.append((char) ('0' + res[i]));}return str.length() == 0 ? "0" : str.toString();}
}

http://www.ppmy.cn/embedded/53946.html

相关文章

常用的通信协议有哪些

常用的通信协议有很多种&#xff0c;主要根据其应用领域和通信需求可以分为几类&#xff1a; 网络通信协议&#xff1a; TCP/IP&#xff1a;传输控制协议/互联网协议&#xff0c;用于互联网及局域网通信。 UDP&#xff1a;用户数据报协议&#xff0c;用于实时数据传输&#…

使用Spring Boot Actuator监控应用健康状态

使用Spring Boot Actuator监控应用健康状态 大家好&#xff0c;我是免费搭建查券返利机器人省钱赚佣金就用微赚淘客系统3.0的小编&#xff0c;也是冬天不穿秋裤&#xff0c;天冷也要风度的程序猿&#xff01;今天我们将探讨如何利用Spring Boot Actuator来监控和管理应用程序的…

0122__linux之eventfd理解

linux之eventfd理解-CSDN博客 Linux fd 系列 — eventfd 是什么&#xff1f;-CSDN博客

大势智慧有软件可以做激光点与倾斜的融合建模吗?

答&#xff1a;重建大师可以融合建模 重建大师是一款专为超大规模实景三维数据生产而设计的集群并行处理软件&#xff0c;输入倾斜照片&#xff0c;激光点云&#xff0c;POS信息及像控点&#xff0c;输出高精度彩色网格模型&#xff0c;可一键完成空三、自动建模和LOD构建。 …

真实还原汽车引擎声浪——WT2003Hx语音芯片方案

PART.01 产品市场 WT2003Hx是一款高性能的MP3音频解码芯片&#xff0c;具有成本效益、低功耗和高可靠性等特点&#xff0c;适用于多种场景&#xff0c;包括但不限于汽车娱乐系统、玩具、教育设备以及专业音响设备等。在模拟汽车引擎声的应用中&#xff0c;这一芯片的特性被特…

简单理解爬虫的概念

简单来说&#xff1a; 爬虫&#xff0c;即网络蜘蛛&#xff0c;是伪装成客户端与服务器进行数据交互的程序。 代码 代码教程分享&#xff08;无偿&#xff09;&#xff1a; 思路 1.获取网页的源码 pythondef askURL(url):head{"User-Agent":"Mozilla/5.0 (L…

单片机+DS18B20温度控制程序仿真与原理图PCB文件 可设上下限

资料下载地址&#xff1a;单片机DS18B20温度控制程序仿真与原理图PCB文件 可设上下限 目录 1、项目介绍 2、实物图 ​3、电路原理图 ​4、仿真原理图 ​5、部分代码 1、项目介绍 基于51单片机温度控制&#xff0c;使用18b20来做温度传感器&#xff0c;四位共阳数码管显…

DevOps搭建-JDK安装

当在进行DevOps搭建时&#xff0c;JDK&#xff08;Java Development Kit&#xff09;的安装是非常重要的一步&#xff0c;因为许多开发和部署工具都依赖于Java。以下是安装JDK的详细步骤&#xff1a; 下载JDK安装包&#xff1a; 访问Oracle官方网站或OpenJDK项目网站&#xf…