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

相关文章

Linux进程CPU绑定优化与实践过程

《Linux进程CPU绑定优化与实践过程》Linux支持进程绑定至特定CPU核心,通过sched_setaffinity系统调用和taskset工具实现,优化缓存效率与上下文切换,提升多核计算性能,适... 目录1. 多核处理器及并行计算概念1.1 多核处理器架构概述1.2 并行计算的含义及重要性1.3 并

Spring boot整合dubbo+zookeeper的详细过程

《Springboot整合dubbo+zookeeper的详细过程》本文讲解SpringBoot整合Dubbo与Zookeeper实现API、Provider、Consumer模式,包含依赖配置、... 目录Spring boot整合dubbo+zookeeper1.创建父工程2.父工程引入依赖3.创建ap

Linux下进程的CPU配置与线程绑定过程

《Linux下进程的CPU配置与线程绑定过程》本文介绍Linux系统中基于进程和线程的CPU配置方法,通过taskset命令和pthread库调整亲和力,将进程/线程绑定到特定CPU核心以优化资源分配... 目录1 基于进程的CPU配置1.1 对CPU亲和力的配置1.2 绑定进程到指定CPU核上运行2 基于

Python中反转字符串的常见方法小结

《Python中反转字符串的常见方法小结》在Python中,字符串对象没有内置的反转方法,然而,在实际开发中,我们经常会遇到需要反转字符串的场景,比如处理回文字符串、文本加密等,因此,掌握如何在Pyt... 目录python中反转字符串的方法技术背景实现步骤1. 使用切片2. 使用 reversed() 函

Java进程异常故障定位及排查过程

《Java进程异常故障定位及排查过程》:本文主要介绍Java进程异常故障定位及排查过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、故障发现与初步判断1. 监控系统告警2. 日志初步分析二、核心排查工具与步骤1. 进程状态检查2. CPU 飙升问题3. 内存

MySQL查询JSON数组字段包含特定字符串的方法

《MySQL查询JSON数组字段包含特定字符串的方法》在MySQL数据库中,当某个字段存储的是JSON数组,需要查询数组中包含特定字符串的记录时传统的LIKE语句无法直接使用,下面小编就为大家介绍两种... 目录问题背景解决方案对比1. 精确匹配方案(推荐)2. 模糊匹配方案参数化查询示例使用场景建议性能优

SpringBoot整合liteflow的详细过程

《SpringBoot整合liteflow的详细过程》:本文主要介绍SpringBoot整合liteflow的详细过程,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋...  liteflow 是什么? 能做什么?总之一句话:能帮你规范写代码逻辑 ,编排并解耦业务逻辑,代码

Java中调用数据库存储过程的示例代码

《Java中调用数据库存储过程的示例代码》本文介绍Java通过JDBC调用数据库存储过程的方法,涵盖参数类型、执行步骤及数据库差异,需注意异常处理与资源管理,以优化性能并实现复杂业务逻辑,感兴趣的朋友... 目录一、存储过程概述二、Java调用存储过程的基本javascript步骤三、Java调用存储过程示

MySQL中的InnoDB单表访问过程

《MySQL中的InnoDB单表访问过程》:本文主要介绍MySQL中的InnoDB单表访问过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、环境3、访问类型【1】const【2】ref【3】ref_or_null【4】range【5】index【6】

浏览器插件cursor实现自动注册、续杯的详细过程

《浏览器插件cursor实现自动注册、续杯的详细过程》Cursor简易注册助手脚本通过自动化邮箱填写和验证码获取流程,大大简化了Cursor的注册过程,它不仅提高了注册效率,还通过友好的用户界面和详细... 目录前言功能概述使用方法安装脚本使用流程邮箱输入页面验证码页面实战演示技术实现核心功能实现1. 随机