【力扣刷题练习】415. 字符串相加

题目描述:

给定两个字符串形式的非负整数 num1 和num2 ,计算它们的和并同样以字符串形式返回。

你不能使用任何內建的用于处理大整数的库(比如 BigInteger), 也不能直接将输入的字符串转换为整数形式。

题目解答:

class Solution {
public:string addStrings(string a, string b) {if (a == "0" && b == "0")return "0";string ans = "";const int maxn = 10001;int numa[maxn] = {0}, numb[maxn] = {0}, num[maxn] = {0};int len = a.length() > b.length() ? a.length() : b.length();int lena = a.length() - 1, lenb = b.length() - 1;for (int i = len; i >= 1; i--) {if (lena != -1)numa[i] = a[lena--] - '0';}for (int i = len; i >= 1; i--) {if (lenb != -1)numb[i] = b[lenb--] - '0';}for (int i = len; i >= 1; i--) {num[i] = num[i] + numa[i] + numb[i];while (num[i] >= 10) {num[i] -= 10;num[i - 1]++;}}int flag = 0;for (int i = 0; i <= len; i++) {if (num[i] == 0 && flag == 0)continue;flag = 1;ans.push_back(num[i] + '0');}return ans;}
};

题目思路:

特殊情况处理:

如果两个输入字符串都是"0",则直接返回"0"。

初始化:

定义一个空字符串ans,用于存储最终的结果。
定义一个常量maxn为10001,用于确定数组的大小。
定义三个整数数组numa, numb, 和num,并初始化为0。这些数组用于存储数字的每一位。

确定长度:

确定两个输入字符串中的最长长度,并将该长度存储在变量len中。
确定输入字符串a的长度并存储在变量lena中,同时确定输入字符串b的长度并存储在变量lenb中。

获取每一位数字:

从后向前遍历输入字符串a,将每一位数字存储在数组numa中。
从后向前遍历输入字符串b,将每一位数字存储在数组numb中。

相加数字:

从后向前遍历数组numa和numb,将它们对应的位相加,并将结果存储在数组num中。如果相加的结果大于或等于10,则需要进行进位处理。

处理进位和结果拼接:

使用变量flag来标记是否已经处理过进位。初始化时设为0。
从后向前遍历数组num,如果当前位是0且之前没有处理过进位(即flag为0),则跳过;否则,将当前位拼接到结果字符串中,并将flag设为1。

返回结果:

返回存储最终结果的字符串
这个方法的基本思路是先将输入的字符串转换为数字数组,然后从低位到高位逐位相加,同时处理进位。最后,将结果从低位到高位拼接为一个字符串并返回。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/661021.shtml

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

相关文章

分布式搜索引擎_学习笔记_3

分布式搜索引擎03 0.学习目标 1.数据聚合 **聚合&#xff08;aggregations&#xff09;**可以让我们极其方便的实现对数据的统计、分析、运算。例如&#xff1a; 什么品牌的手机最受欢迎&#xff1f;这些手机的平均价格、最高价格、最低价格&#xff1f;这些手机每月的销售…

Postgresql使用update

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 解决问题一、关联表更新1.关联一张表2.关联多张表 二、根据状态更新为不同的值 解决问题 通过多张关联表更新主表的字段&#xff0c;根据状态更新为不同的值。 一、…

2670--------找出不同元素数目差数组

题目&#xff1a; 给你一个下标从 0 开始的数组 nums &#xff0c;数组长度为 n 。 nums 的 不同元素数目差 数组可以用一个长度为 n 的数组 diff 表示&#xff0c;其中 diff[i] 等于前缀 nums[0, ..., i] 中不同元素的数目 减去 后缀 nums[i 1, ..., n - 1] 中不同元素的数…

matlab中的图窗属性和坐标轴的属性

图窗的Position和Outerposition Position 指定窗口的尺寸和窗口在屏幕中的位置。 Outerposition 指定窗口外轮廓的大小和位置。 两者都是用一个4维向量来定义&#xff0c;格式为[左 底 宽 高]。 可通过set函数修改Position和Outerposition&#xff0c;如下&#xff1a;在屏幕左…

跨平台销售策略:通过API同步不同市场的商品数据

在数字化时代&#xff0c;零售商和品牌经常需要在不同的在线市场上展示和销售商品。为了保持竞争力并确保一致的客户体验&#xff0c;商家必须确保其商品信息在所有渠道上保持同步和准确。这种需求催生了跨平台销售策略&#xff0c;其中一个关键组成部分就是利用应用程序编程接…

spice-gtk注册glib错误信息

首先生成spice统一的错误域 #define SPICE_CLIENT_ERROR spice_client_error_quark()GQuark spice_client_error_quark(void) {return g_quark_from_static_string("spice-client-error-quark"); } 方法1&#xff1a;通过g_set_error()函数 g_set_error(err, SPICE_C…

color - 让你的输出带点颜色

color color 是一个可以让你输出带颜色文本的库。 安装 go get github.com/fatih/color示例 输出到控制台 // 这会直接输出到控制台 color.Cyan("Prints text in cyan.")// 每个调用末尾会自动加上换行 color.Blue("Prints %s in blue.", "text&…

VMware vCenter告警:vSphere UI运行状况警报

vSphere UI运行状况警报 不会详细显示告警的具体内容&#xff0c;需要我们自己进一步确认告警原因。 vSphere UI运行状况警报是一种监控工具&#xff0c;用于检测vSphere环境中的潜在问题。当警报触发时&#xff0c;通常表示系统遇到了影响性能或可用性的问题。解决vSphere UI…

软件测试之软件缺陷管理

什么是软件缺陷 标准的定义&#xff1a;从产品内部看&#xff0c;缺陷是软件产品开发或维护过程中存在的错误、毛病等各种问题&#xff1b;从产品外部看&#xff0c;缺陷是系统所需要实现的某种功能的失效或违背 软件缺陷的生命周期 一个缺陷的正常生命周期是 新建&#xff…

【Java】Java的对象参数踩坑总结

文章目录 前言失败的修改成功的修改原理分析基本类型参数对象引用参数 举一反三&#xff1a;不修改对象参数怎么写&#xff1f; 前言 今天写代码的时候&#xff0c;犯了一个很基础很低级的错误。实在惭愧&#xff0c;在此花点顺手记录一下&#xff0c;养成习惯。 需求是需要把…

如何分辨坏信息?

每当有社会热点&#xff0c;大家也许都会遇到一个困扰&#xff1a; 铺天盖地的信息&#xff0c;实在是太多了。究竟哪一些值得信任&#xff0c;哪些不值得信任&#xff1f;哪些可以接受&#xff0c;哪些最好保持怀疑&#xff1f; 我想用这篇文章&#xff0c;彻底把这个问题讲清…

CSS定位

定位的组成&#xff1a; 这个属性只有当position属性设置为absolute、fixed、relative时才有效。而且在position属性取值不同时&#xff0c;它们的含义也不同。left和right属性值除了可以设置为绝对的像素数外&#xff0c;还可以设置百分数。 定位模式&#xff1a; 静态定位st…

易语言系列学习1

通过本文章你会学习到 如果 如果真 获取编辑框内容 关闭本程序 监听按键让它等价于点击某个按钮 运算&#xff1a;或 且 非&#xff08;注意中间要有一个空格&#xff0c;否则会报错&#xff09; 效果 .版本 2.程序集 窗口程序集_启动窗口.子程序 _按钮2_被单击. 如果真 (编…

QT生成二维码

文章目录 1.基于第三方库libqrencode,Qt本地生成二维码1.1.效果图1.2.QR码简介1.3.第三方库libqrencode下载1.4.在自己的项目中使用,这里提供一个例子1.4.1.新建一个工程1.4.2.加入第三方库libqrencode1.4.3.qrencode.pri1.4.4.使用1.4.5.centos7下编译运行1.4.6.Windows下编译…

【项目实践02】【优先级阻塞队列】

文章目录 一、前言二、项目背景三、实现方案四、思路延伸1. 优先级队列1.1 concurrent 包下的 PriorityBlockingQueue1.2 Redisson 的优先级阻塞队列 2. jvisualvm 远程连接3. Jstack 高 CPU 排查 五、参考内容 一、前言 本系列用来记录一些在实际项目中的小东西&#xff0c;并…

qemu 抓取linux kernel vmcore

一、背景 在qemu调试linux kernel时 有时我们会遇到dump 情况&#xff0c;这时可以通过gdb 方式连接分析dump&#xff0c; 但实际中我们用得更多的是离线dump 分析&#xff0c;分析的文件通常是vmcore&#xff08;linux kernel panic 生成的coredump文件&#xff09;或者ramdu…

【多个SpringBoot模块项目如何变成聚合项目】

【前言】 项目虽然是Eureka、OpenFeign 进行服务注册和服务调用&#xff0c;但是每个模块都是一个单独的SpringBoot&#xff0c;启动每个模块都需要单独启动一个idea,觉得这个过于繁琐&#xff0c;现在想把项目变成一个聚合项目&#xff0c;只需要启动一个idea即可。 【过程】…

Mybatis批量增删改查

1.批量新增 mapper层&#xff1a; Integer batchAdd(Param("list")List<UserEntity> userEntity); xml&#xff1a; <insert id"batchAdd" parameterType"java.util.List">INSERT INTO 表名(name, age, gender, psw, seq) value…

Spring相关框架中的bean及其实例化

目录 一、什么是实例化 二、Spring中的依赖注入 三、Bean的生命周期 四、Spring容器及作用 五、在Spring Boot中如何使用容器 一、什么是实例化 在 Spring 框架中&#xff0c;实例化通常是指创建一个对象的过程。具体来说&#xff0c;当你在 Spring 中配置一个 Bean&…

QTimer 指针类型和引用类型使用的区别

QTimer *timer1 new QTimer(this); //指针类型 QTimer timer2; //引用类型 这两种用法之间的主要区别在于对象的生命周期和存储位置。 1、动态分配内存的对象*timer1 &#xff1a; QTimer在创建为 *timer1 指针类型时&#xff0c;一定要指定this为父类&#xff0c;即父类为…