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设置环境变量路径实现过程

《python设置环境变量路径实现过程》本文介绍设置Python路径的多种方法:临时设置(Windows用`set`,Linux/macOS用`export`)、永久设置(系统属性或shell配置文件... 目录设置python路径的方法临时设置环境变量(适用于当前会话)永久设置环境变量(Windows系统

python运用requests模拟浏览器发送请求过程

《python运用requests模拟浏览器发送请求过程》模拟浏览器请求可选用requests处理静态内容,selenium应对动态页面,playwright支持高级自动化,设置代理和超时参数,根据需... 目录使用requests库模拟浏览器请求使用selenium自动化浏览器操作使用playwright

Mysql中设计数据表的过程解析

《Mysql中设计数据表的过程解析》数据库约束通过NOTNULL、UNIQUE、DEFAULT、主键和外键等规则保障数据完整性,自动校验数据,减少人工错误,提升数据一致性和业务逻辑严谨性,本文介绍My... 目录1.引言2.NOT NULL——制定某列不可以存储NULL值2.UNIQUE——保证某一列的每一

解密SQL查询语句执行的过程

《解密SQL查询语句执行的过程》文章讲解了SQL语句的执行流程,涵盖解析、优化、执行三个核心阶段,并介绍执行计划查看方法EXPLAIN,同时提出性能优化技巧如合理使用索引、避免SELECT*、JOIN... 目录1. SQL语句的基本结构2. SQL语句的执行过程3. SQL语句的执行计划4. 常见的性能优

C# $字符串插值的使用

《C#$字符串插值的使用》本文介绍了C#中的字符串插值功能,详细介绍了使用$符号的实现方式,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧... 目录$ 字符使用方式创建内插字符串包含不同的数据类型控制内插表达式的格式控制内插表达式的对齐方式内插表达式中使用转义序列内插表达式中使用

电脑提示d3dx11_43.dll缺失怎么办? DLL文件丢失的多种修复教程

《电脑提示d3dx11_43.dll缺失怎么办?DLL文件丢失的多种修复教程》在使用电脑玩游戏或运行某些图形处理软件时,有时会遇到系统提示“d3dx11_43.dll缺失”的错误,下面我们就来分享超... 在计算机使用过程中,我们可能会遇到一些错误提示,其中之一就是缺失某个dll文件。其中,d3dx11_4

linux下shell脚本启动jar包实现过程

《linux下shell脚本启动jar包实现过程》确保APP_NAME和LOG_FILE位于目录内,首次启动前需手动创建log文件夹,否则报错,此为个人经验,供参考,欢迎支持脚本之家... 目录linux下shell脚本启动jar包样例1样例2总结linux下shell脚本启动jar包样例1#!/bin

详解MySQL中JSON数据类型用法及与传统JSON字符串对比

《详解MySQL中JSON数据类型用法及与传统JSON字符串对比》MySQL从5.7版本开始引入了JSON数据类型,专门用于存储JSON格式的数据,本文将为大家简单介绍一下MySQL中JSON数据类型... 目录前言基本用法jsON数据类型 vs 传统JSON字符串1. 存储方式2. 查询方式对比3. 索引

java内存泄漏排查过程及解决

《java内存泄漏排查过程及解决》公司某服务内存持续增长,疑似内存泄漏,未触发OOM,排查方法包括检查JVM配置、分析GC执行状态、导出堆内存快照并用IDEAProfiler工具定位大对象及代码... 目录内存泄漏内存问题排查1.查看JVM内存配置2.分析gc是否正常执行3.导出 dump 各种工具分析4.

MySQL字符串常用函数详解

《MySQL字符串常用函数详解》本文给大家介绍MySQL字符串常用函数,本文结合实例代码给大家介绍的非常详细,对大家学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录mysql字符串常用函数一、获取二、大小写转换三、拼接四、截取五、比较、反转、替换六、去空白、填充MySQL字符串常用函数一、