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

相关文章

oracle 11g导入\导出(expdp impdp)之导入过程

《oracle11g导入导出(expdpimpdp)之导入过程》导出需使用SEC.DMP格式,无分号;建立expdir目录(E:/exp)并确保存在;导入在cmd下执行,需sys用户权限;若需修... 目录准备文件导入(impdp)1、建立directory2、导入语句 3、更改密码总结上一个环节,我们讲了

Java实现将HTML文件与字符串转换为图片

《Java实现将HTML文件与字符串转换为图片》在Java开发中,我们经常会遇到将HTML内容转换为图片的需求,本文小编就来和大家详细讲讲如何使用FreeSpire.DocforJava库来实现这一功... 目录前言核心实现:html 转图片完整代码场景 1:转换本地 HTML 文件为图片场景 2:转换 H

Python实现精确小数计算的完全指南

《Python实现精确小数计算的完全指南》在金融计算、科学实验和工程领域,浮点数精度问题一直是开发者面临的重大挑战,本文将深入解析Python精确小数计算技术体系,感兴趣的小伙伴可以了解一下... 目录引言:小数精度问题的核心挑战一、浮点数精度问题分析1.1 浮点数精度陷阱1.2 浮点数误差来源二、基础解决

ShardingProxy读写分离之原理、配置与实践过程

《ShardingProxy读写分离之原理、配置与实践过程》ShardingProxy是ApacheShardingSphere的数据库中间件,通过三层架构实现读写分离,解决高并发场景下数据库性能瓶... 目录一、ShardingProxy技术定位与读写分离核心价值1.1 技术定位1.2 读写分离核心价值二

MyBatis-plus处理存储json数据过程

《MyBatis-plus处理存储json数据过程》文章介绍MyBatis-Plus3.4.21处理对象与集合的差异:对象可用内置Handler配合autoResultMap,集合需自定义处理器继承F... 目录1、如果是对象2、如果需要转换的是List集合总结对象和集合分两种情况处理,目前我用的MP的版本

Java Kafka消费者实现过程

《JavaKafka消费者实现过程》Kafka消费者通过KafkaConsumer类实现,核心机制包括偏移量管理、消费者组协调、批量拉取消息及多线程处理,手动提交offset确保数据可靠性,自动提交... 目录基础KafkaConsumer类分析关键代码与核心算法2.1 订阅与分区分配2.2 拉取消息2.3

Java使用正则提取字符串中的内容的详细步骤

《Java使用正则提取字符串中的内容的详细步骤》:本文主要介绍Java中使用正则表达式提取字符串内容的方法,通过Pattern和Matcher类实现,涵盖编译正则、查找匹配、分组捕获、数字与邮箱提... 目录1. 基础流程2. 关键方法说明3. 常见场景示例场景1:提取所有数字场景2:提取邮箱地址4. 高级

Python文本相似度计算的方法大全

《Python文本相似度计算的方法大全》文本相似度是指两个文本在内容、结构或语义上的相近程度,通常用0到1之间的数值表示,0表示完全不同,1表示完全相同,本文将深入解析多种文本相似度计算方法,帮助您选... 目录前言什么是文本相似度?1. Levenshtein 距离(编辑距离)核心公式实现示例2. Jac

AOP编程的基本概念与idea编辑器的配合体验过程

《AOP编程的基本概念与idea编辑器的配合体验过程》文章简要介绍了AOP基础概念,包括Before/Around通知、PointCut切入点、Advice通知体、JoinPoint连接点等,说明它们... 目录BeforeAroundAdvise — 通知PointCut — 切入点Acpect — 切面

C++ STL-string类底层实现过程

《C++STL-string类底层实现过程》本文实现了一个简易的string类,涵盖动态数组存储、深拷贝机制、迭代器支持、容量调整、字符串修改、运算符重载等功能,模拟标准string核心特性,重点强... 目录实现框架一、默认成员函数1.默认构造函数2.构造函数3.拷贝构造函数(重点)4.赋值运算符重载函数