当前位置: 首页 > news >正文

字符串-43.字符串相乘-力扣(LeetCode)

一、题目解析

1、计算乘积后,将结果也按字符串返回

2、字符串长度在[1,200]

二、算法原理

为了方便字符串计算,我们将其逆置,符合我们的计算需求,"123"将变为"321"

解法1:模拟小学列竖式计算

但还是有细节需要注意

细节1:在高位相乘时,要补上“0”

我们自己在计算时,不加0,是因为我们知道哪里是有0的,只是懒得写。但对于我们计算字符串相加时,不加0,会导致计算出错,所以要补上0

细节2:处理前导“0”

在计算123x0的时候,由于我们对字符串进行处理,所以会出现"000"这样的结果,所以需要特殊处理一下

细节3:注意计算结果的顺序

我们逆序了相乘的字符串,但我们计算的结果也是逆序的,所以我们需要对结果进行逆置

解法2:对解法1的优化

对于解法1,我们需要处理多次进位,计算123*6,123*50,123*400的时候需要处理进位,在计算和的时候也需要处理进位,这就导致了代码实现十分麻烦,所以在此基础上提出了优化

将计算完的每一位先不处理进位,将其放入到一个数组tmp中,存放的位置也很好知道,从右往左数3是第0位,2是第1位,1是第2位,对于3*6的结果18应该放在数组下标0+0处,同理6*2的结果12放在数组下标1+0处,如此操作完后我们最后最数组内存存储的值做进位计算

用ret存储字符串,记得逆置哦

个人建议第一种解法看看官方代码就行了,真要好理解好上手,还得看解法2

链接:43. 字符串相乘 - 力扣(LeetCode)

三、代码示例

解法2:

class Solution {
public:int tmp[399];//这里直接开399是因为最长只有200,不超过400,虽然有点浪费string multiply(string num1, string num2){int m = num1.size(),n = num2.size();string ret;reverse(num1.begin(),num1.end());reverse(num2.begin(),num2.end());for(int i = 0;i<n;i++){for(int j = 0;j<m;j++){tmp[i+j] += (num1[j]-'0')*(num2[i]-'0');}}int carry = 0;for(int i = 0;i<m+n-1;i++){ret += to_string((tmp[i]+carry)%10);carry = (tmp[i]+carry)/10;}if(carry) ret += to_string(carry);//需要对保存进位做判断,不为0则说明字符串不完整reverse(ret.begin(),ret.end());if(ret[0]=='0'&&ret[1]=='0')//前导0特判return "0";return ret;}
};

看到最后,如果对您有所帮助,还请点赞、收藏和关注一键三连,在未来还会继续带来优秀的内容,感谢观看,我们下期再见!


文章转载自:

http://InfrPbbt.pcqdf.cn
http://9akTo7bH.pcqdf.cn
http://6E3RCWbD.pcqdf.cn
http://JTysVtZL.pcqdf.cn
http://uqEV0JLm.pcqdf.cn
http://7axXjP9N.pcqdf.cn
http://xhlhzCf9.pcqdf.cn
http://fN6OqnHe.pcqdf.cn
http://HjBLfWc5.pcqdf.cn
http://R8ImkKaJ.pcqdf.cn
http://YPrciPkI.pcqdf.cn
http://ok0GZJ27.pcqdf.cn
http://3q9RdugB.pcqdf.cn
http://IUUwhyKP.pcqdf.cn
http://cw9qtqB4.pcqdf.cn
http://HDQLJw9E.pcqdf.cn
http://WkGFjE8c.pcqdf.cn
http://osib5bHq.pcqdf.cn
http://QfCrNABC.pcqdf.cn
http://wzFsSGQ4.pcqdf.cn
http://5eclsQ0o.pcqdf.cn
http://6ZN7Nv4K.pcqdf.cn
http://I2yjxWBf.pcqdf.cn
http://xvseusxK.pcqdf.cn
http://YP9rjCtj.pcqdf.cn
http://wKA5nnVa.pcqdf.cn
http://dpXfJneu.pcqdf.cn
http://2Qy0CBsu.pcqdf.cn
http://NCTFw46I.pcqdf.cn
http://Njntmn3b.pcqdf.cn
http://www.dtcms.com/a/379192.html

相关文章:

  • java properties/反射基础
  • solidity的高阶语法4
  • Vue.js Data定义方式对比 data() { return {...} } 与 data: {} 的区别
  • P11961原根判断(1)
  • 特征空间的转换方法 IPM/LSS/Transformer
  • 【Vue3】05-Options API和Composition API的区别
  • 锁框架-面试
  • 电商 API 爬虫高阶技巧:多线程 / 异步请求结合,突破接口频率限制
  • vue两个组件互相引入时候会报错
  • 《芯片封装后未测试品粘连及边缘残胶的多维度工艺与材料失效分析》
  • MySQL基础全面解析
  • 探索容器技术:从LXC到Podman的演进
  • IntelliJ IDEA 启动项目时配置端口指南
  • java 实现rtsp 直播流下载
  • Python高级编程实战:装饰器、迭代器与生成器的深度应用
  • 高级SQL技术综合指南(MySQL)
  • 【51单片机】【protues仿真】基于51单片机电子琴系统
  • 解决idea2021maven依赖导入后还是找不到包,爆红无法导入
  • Netty学习
  • VGGNet:为什么16层简单堆叠能成为CNN经典?
  • 知识图谱RAG
  • 与controller层的接口入参注解@Valid有关的实体类判断空的注解
  • 基于AT89C52单片机的智能蓝牙台灯设计
  • Javaweb前端内容的思维导图
  • PyTorch深度学习实战【10】之神经网络的损失函数
  • 3.前置知识学习
  • Whois查询域名信息
  • 机器学习vs人类学习:人类学习如何借鉴机器学习方法?
  • ES6 面试题及详细答案 80题 (41-54)-- 异步编程(Promise/Generator/async)
  • Bug记录:Lombok @Builder 注解的两大陷阱及解决方案