43字符串相乘(暴力模拟竖式乘法计算过程)

2023-10-04 21:50

本文主要是介绍43字符串相乘(暴力模拟竖式乘法计算过程),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、题目描述

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

说明:

num1 和 num2 的长度小于110。
num1 和 num2 只包含数字 0-9。
num1 和 num2 均不以零开头,除非是数字 0 本身。
不能使用任何标准库的大数类型(比如 BigInteger)或直接将输入转换为整数来处理。

2、示例

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

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

3、题解

基本思想:暴力模拟竖式乘法计算过程,两重循环第一重循环读取num2中某个数与第二重循环读取num1所有数相乘这就是一层结果layer,然后将每一层结果加到res最后返回res的逆序。

  • layer为num2中某个数与num1所有数相乘结果也就是一层结果,将每一层结果加到res就是最后返回结果。cur是num1中某个数字和num2某个数字相乘得到结果的个位数。temp临时num1和num2某两个数字对应相乘结果,carry是结果的十位数也就是进位数。
  • 如果num1和num2中有一个是0,结果返回0
  • 第一重循环读取num2中某个数,每一层layer初始化为空,根据num2中读取数所在的位数,layer添加相应个数的0,进位数carry初始化为0
  • 第二重循环读取num1所有数与num2读取的数num2[i]相乘得到这一层结果layer
  • 如果num2[i]与num1所有数相乘后还有进位,加到layer后面
  • 然后将每一层结果layer加到res上
  • 可能layer的长度大于res的长度,layer大于res长度的部分加到res后面
  • 考虑可能最后还有进位
  • 最后返回res的逆序
#include<iostream>
#include<vector>
#include<algorithm>
using namespace std;
class Solution {
public:string multiply(string num1, string num2) {int l1 = num1.size();int l2 = num2.size();string res(l1 + l2, '0');for(int i=l1-1; i>=0; i--) {for(int j=l2-1; j>=0; j--) {int tmp = (res[i+j+1] - '0') + (num1[i] - '0')*(num2[j] - '0'); res[i+j+1] = tmp%10 + '0';res[i+j] += tmp/10;}}for(int i = 0; i < l1+l2; i++){if(res[i]!='0') return res.substr(i);}return "0";     }
};
class Solution {
public:string multiply(string num1, string num2) {//基本思想:暴力模拟竖式乘法计算过程,两重循环第一重循环读取num2中某个数与第二重循环读取num1所有数相乘这就是一层结果layer,然后将每一层结果加到res最后返回res的逆序//layer为num2中某个数与num1所有数相乘结果也就是一层结果,将每一层结果加到res就是最后返回结果string res, layer;//cur是num1中某个数字和num2某个数字相乘得到结果的个位数char cur;//temp临时num1和num2某两个数字对应相乘结果,carry是结果的十位数也就是进位数int i, j, carry, temp, k;//如果num1和num2中有一个是0,结果返回0if (num1 == "0" || num2 == "0")return "0";//第一重循环读取num2中某个数for (i = num2.size() - 1; i >= 0; i--){//每一层layer初始化为空layer = "";//根据num2中读取数所在的位数,layer添加相应个数的0for (k = 0; k < num2.size() - 1 - i; k++)layer.push_back('0');//进位数carry初始化为0carry = 0;//第二重循环读取num1所有数与num2读取的数num2[i]相乘得到这一层结果layerfor (j = num1.size() - 1; j >= 0; j--){temp = (num2[i] - '0') * (num1[j] - '0') + carry;cur = temp % 10 + '0';carry = temp / 10;layer.push_back(cur);		}//如果num2[i]与num1所有数相乘后还有进位,加到layer后面if (carry > 0)layer.push_back(carry + '0');carry = 0;//然后将每一层结果layer加到res上for (k = 0; k < res.size() && k < layer.size(); k++){temp = (res[k] - '0') + (layer[k] - '0') + carry;res[k] = temp % 10 + '0';carry = temp / 10;}//可能layer的长度大于res的长度,layer大于res长度的部分加到res后面while (k < layer.size()){temp = layer[k] - '0' + carry;res.push_back(temp % 10 + '0');carry = temp / 10;k++;}//考虑可能最后还有进位if (carry == 1)res.push_back('1');}//最后返回res的逆序reverse(res.begin(), res.end());return res;}
};
int main()
{Solution solute;string nums1 = "23";string nums2 = "112";cout << solute.multiply(nums1, nums2) << endl;return 0;
}

 

这篇关于43字符串相乘(暴力模拟竖式乘法计算过程)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/2792

相关文章

使用Python实现base64字符串与图片互转的详细步骤

《使用Python实现base64字符串与图片互转的详细步骤》要将一个Base64编码的字符串转换为图片文件并保存下来,可以使用Python的base64模块来实现,这一过程包括解码Base64字符串... 目录1. 图片编码为 Base64 字符串2. Base64 字符串解码为图片文件3. 示例使用注意

Spring Boot 整合 Apache Flink 的详细过程

《SpringBoot整合ApacheFlink的详细过程》ApacheFlink是一个高性能的分布式流处理框架,而SpringBoot提供了快速构建企业级应用的能力,下面给大家介绍Spri... 目录Spring Boot 整合 Apache Flink 教程一、背景与目标二、环境准备三、创建项目 & 添

pytest+allure环境搭建+自动化实践过程

《pytest+allure环境搭建+自动化实践过程》:本文主要介绍pytest+allure环境搭建+自动化实践过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、pytest下载安装1.1、安装pytest1.2、检测是否安装成功二、allure下载安装2.

Pytorch介绍与安装过程

《Pytorch介绍与安装过程》PyTorch因其直观的设计、卓越的灵活性以及强大的动态计算图功能,迅速在学术界和工业界获得了广泛认可,成为当前深度学习研究和开发的主流工具之一,本文给大家介绍Pyto... 目录1、Pytorch介绍1.1、核心理念1.2、核心组件与功能1.3、适用场景与优势总结1.4、优

Redis指南及6.2.x版本安装过程

《Redis指南及6.2.x版本安装过程》Redis是完全开源免费的,遵守BSD协议,是一个高性能(NOSQL)的key-value数据库,Redis是一个开源的使用ANSIC语言编写、支持网络、... 目录概述Redis特点Redis应用场景缓存缓存分布式会话分布式锁社交网络最新列表Redis各版本介绍旧

SpringBoot整合Sa-Token实现RBAC权限模型的过程解析

《SpringBoot整合Sa-Token实现RBAC权限模型的过程解析》:本文主要介绍SpringBoot整合Sa-Token实现RBAC权限模型的过程解析,本文给大家介绍的非常详细,对大家的学... 目录前言一、基础概念1.1 RBAC模型核心概念1.2 Sa-Token核心功能1.3 环境准备二、表结

Jvm sandbox mock机制的实践过程

《Jvmsandboxmock机制的实践过程》:本文主要介绍Jvmsandboxmock机制的实践过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、背景二、定义一个损坏的钟1、 Springboot工程中创建一个Clock类2、 添加一个Controller

Python使用pynput模拟实现键盘自动输入工具

《Python使用pynput模拟实现键盘自动输入工具》在日常办公和软件开发中,我们经常需要处理大量重复的文本输入工作,所以本文就来和大家介绍一款使用Python的PyQt5库结合pynput键盘控制... 目录概述:当自动化遇上可视化功能全景图核心功能矩阵技术栈深度效果展示使用教程四步操作指南核心代码解析

python多线程并发测试过程

《python多线程并发测试过程》:本文主要介绍python多线程并发测试过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、并发与并行?二、同步与异步的概念?三、线程与进程的区别?需求1:多线程执行不同任务需求2:多线程执行相同任务总结一、并发与并行?1、

golang float和科学计数法转字符串的实现方式

《golangfloat和科学计数法转字符串的实现方式》:本文主要介绍golangfloat和科学计数法转字符串的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望... 目录golang float和科学计数法转字符串需要对float转字符串做处理总结golang float