一、题目解析

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://www.pswp.cn/pingmian/96210.shtml
繁体地址,请注明出处:http://hk.pswp.cn/pingmian/96210.shtml
英文地址,请注明出处:http://en.pswp.cn/pingmian/96210.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

鸿蒙HAP包解包、打包、签名及加固全流程解析

在鸿蒙应用开发过程中&#xff0c;HAP&#xff08;HarmonyOS Ability Package&#xff09;包的解包、打包、签名以及加固是开发者们绕不开的重要环节。今天&#xff0c;就让我们深入探讨这一全流程&#xff0c;帮助大家更好地理解和掌握相关操作。 一、HAP解包 解包是分析和修…

PyTorch之张量创建与运算

PyTorch 主要有以下几个基础概念&#xff1a;张量&#xff08;Tensor&#xff09;、自动求导&#xff08;Autograd&#xff09;、神经网络模块&#xff08;nn.Module&#xff09;、优化器&#xff08;optim&#xff09;等。张量&#xff08;Tensor&#xff09;&#xff1a;PyTo…

数据 储存

文件储存 网页版爬虫数据库 &#xff1a; https://spidertools.cn/#/crypto TEXT 文本储存 可以使用记事本打开 r #读取。 r #读写&#xff0c;文件指针放在文件的开头。 w #写入&#xff0c;覆盖原文件。 w #读写&#xff0c;覆盖原文件。 a #附加。 a #读写&…

Flask 博客系统(Flask Blog System)

目标&#xff1a;零基础也能从头搭建一个支持文章管理、评论、分类标签、搜索、用户登录的博客系统 技术栈&#xff1a;Flask SQLite SQLAlchemy Jinja2 HTML/CSS Flask-Login 开发工具&#xff1a;VSCode 学习重点&#xff1a;MVC 模式、数据库操作、会话管理、表单处理一…

基于RFID技术的宠物自动喂食器方案

一、背景 宠物已经成为现代人生活中不可或缺的一部分&#xff0c;随着养宠物的人越来越多&#xff0c;宠物的数量也越来越多&#xff0c;有些家庭甚至养了两只以上的猫狗或者猫狗混养&#xff0c;宠物间的管理问题也越来越突出&#xff0c;如宠物之间的抢食行为&#xff0c;易…

conda常见问题

文章目录run "conda init" before "conda activate"打开PowerShell自动进入base环境&#xff08;cmd没有这个问题&#xff09;run “conda init” before “conda activate” 在使用conda命令创建env后使用conda activate命令&#xff0c;出现"run ‘…

第5章 HTTPS与安全配置

5.1 HTTPS概述 5.1.1 为什么需要HTTPS 数据加密:保护传输中的敏感数据 身份验证:确认服务器身份的真实性 数据完整性:防止数据在传输过程中被篡改 SEO优势:搜索引擎优先排名HTTPS网站 浏览器要求:现代浏览器对HTTP网站显示不安全警告 合规要求:许多行业标准要求使用HTTP…

Java入门级教程17——利用Java SPI机制制作验证码、利用Java RMI机制实现分布式登录验证系统

目录 1.制作验证码——java SPI机制 1.1 类所属包情况 1.2 具体实现 1.2.1 核心接口&#xff1a;ICode 1.2.2 接口实现类&#xff1a;验证码的具体生成逻辑 1.2.3 服务工厂类&#xff1a;CodeServiceFactory&#xff08;核心&#xff1a;SPI 服务发现&#xff09; 1.2.…

ES6笔记5

1. Promise相当于一个容器&#xff0c;保存着未来才要结束的事件&#xff08;异步操作&#xff09;的一个结果&#xff0c;各种异步操作都可以用同样方法处理 axios特点&#xff1a;对象的状态不受外界影响&#xff0c;处理异步操作&#xff0c;3个状态&#xff0c;Pending&…

解决idea2021maven依赖导入后还是找不到包,爆红无法导入

1.依赖导入后pom.xml文件以及Maven,此两处代码还是爆红 2.解决方法 由技术大佬同事几分钟解决,他记忆深刻之前搞过很久,一看就知道哪里出问题了 我之前是配过Maven的本地仓库的但是没有用,这次出问题之后长教训了,技术大佬说尽量用自己的本地仓库,不要用idea的Maven仓库,容易…

【硬件-笔试面试题-81】硬件/电子工程师,笔试面试题(知识点:详细讲讲同步时钟与异步时钟通信)

题目汇总版--链接&#xff1a; 【硬件-笔试面试题】硬件/电子工程师&#xff0c;笔试面试题汇总版&#xff0c;持续更新学习&#xff0c;加油&#xff01;&#xff01;&#xff01;-CSDN博客 【硬件-笔试面试题-81】硬件/电子工程师&#xff0c;笔试面试题&#xff08;知识点…

php计算一个模拟增长过程函数

private function calculateGrowth($progress) {// 使用多个增长阶段模拟不均匀性if ($progress < 0.3) {// 前30%时间&#xff1a;缓慢增长 30 %return pow($progress / 0.3, 0.7) * 0.3;} elseif ($progress < 0.7) {// 中间40%时间&#xff1a;快速增长 50%return 0.3…

华为USG6000v2 NAT模式下IPSEC IKE V1 实验

USG6000v2 NAT模式下IPSEC 实验 拓扑图公网配置OSPF路由协议&#xff08;网络要求能通就行&#xff09; 一、 总部配置 &#xff08;一&#xff09;交换机配置 1、 总部交换机到防火墙网段 192.168.10.0/24 2、 交换机G0/0设置成access端口划分vlan 10&#xff0c;网关 192.168…

android 里设计context的作用

Android中的Context是一个核心设计机制&#xff0c;其作用主要体现在以下几个方面&#xff1a; 1. 提供应用程序环境信息 Context作为抽象类&#xff0c;封装了应用与系统交互所需的全局环境信息&#xff0c;包括资源访问、组件启动、系统服务调用等基础能力。它本质上是应用…

能发弹幕的简单视频网站

界面参考了Youtube&#xff0c;后端使用Spring Boot&#xff0c;前端Vue&#xff0c;vuetifyjs。支持自动生成封面图&#xff0c;发送弹幕、AI内容审核等功能。 一个简单的视频网站 网站名称是 TikTok 与 YouTube 的缝合&#xff0c;Logo 为豆包 AI 生成 主要界面参考了 Yout…

了解网站安全监测系统的重要性

在当今数字化时代&#xff0c;网站已经成为企业发展和品牌推广的关键渠道之一。然而&#xff0c;随之而来的是网络安全威胁的增加&#xff0c;包括数据泄露、恶意攻击和病毒感染等问题。为了保护网站和用户信息的安全&#xff0c;网站安全监测系统变得至关重要。1. 网站安全监测…

fastadmin安装后后台提示putenv()报错,不显示验证码

1.安装fastadmin后&#xff0c;访问项目后台&#xff0c;提示报错&#xff1a;Warning: putenv() has been disabled for security reasons in /www/wwwroot/app.aaa.cn/thinkphp/base.php on line 50 这时候验证码还不显示&#xff0c;怎么解决呢&#xff1f;2.打开php.ini文件…

C语言深度入门系列:第二篇 - 变量与数据类型:程序世界的基本粒子与容器

C语言深度入门系列&#xff1a;第二篇 - 变量与数据类型&#xff1a;程序世界的基本粒子与容器 本章目标 本章将深入探讨程序如何“记住”信息。你将彻底理解变量的本质是内存中的一块空间&#xff0c;数据类型是解释这块内存中0和1的规则。我们将超越简单的int, float用法&…

十一旅游中国气象攻略:如何评估降雨、大风与紫外线

一、十一期间的中国气候态要点(10 月上旬) 冷空气南下增多:华北—东北易大风降温;长江以南易出现冷暖空气交汇降雨。 台风未完全退场:华南沿海与海南、华东沿海仍可能受外围环流与风雨影响。 昼夜温差扩大:西北、华北、内陆盆地早晚凉,白天热,雾/霜风险抬头。 高原与…

鸿蒙项目篇-21-创建项目、修改软件文字/图标

目录 【预览】修改配置文件 module.json5 创建项目 初次-运行预览 拷贝图片 用于替换 【实操】修改配置文件 module.json5 点击,显示引用 ctrl + 点击,引用追踪 置顶模拟器 最终代码 总结 先规划再行动【高效】以终为始【不偏离方向/目标】 【预览】修改配置文件 m…