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

2024-02-01 18:04

本文主要是介绍【力扣刷题练习】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。

返回结果:

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

这篇关于【力扣刷题练习】415. 字符串相加的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/668032

相关文章

Java中String字符串使用避坑指南

《Java中String字符串使用避坑指南》Java中的String字符串是我们日常编程中用得最多的类之一,看似简单的String使用,却隐藏着不少“坑”,如果不注意,可能会导致性能问题、意外的错误容... 目录8个避坑点如下:1. 字符串的不可变性:每次修改都创建新对象2. 使用 == 比较字符串,陷阱满

IDEA编译报错“java: 常量字符串过长”的原因及解决方法

《IDEA编译报错“java:常量字符串过长”的原因及解决方法》今天在开发过程中,由于尝试将一个文件的Base64字符串设置为常量,结果导致IDEA编译的时候出现了如下报错java:常量字符串过长,... 目录一、问题描述二、问题原因2.1 理论角度2.2 源码角度三、解决方案解决方案①:StringBui

C#从XmlDocument提取完整字符串的方法

《C#从XmlDocument提取完整字符串的方法》文章介绍了两种生成格式化XML字符串的方法,方法一使用`XmlDocument`的`OuterXml`属性,但输出的XML字符串不带格式,可读性差,... 方法1:通过XMLDocument的OuterXml属性,见XmlDocument类该方法获得的xm

JSON字符串转成java的Map对象详细步骤

《JSON字符串转成java的Map对象详细步骤》:本文主要介绍如何将JSON字符串转换为Java对象的步骤,包括定义Element类、使用Jackson库解析JSON和添加依赖,文中通过代码介绍... 目录步骤 1: 定义 Element 类步骤 2: 使用 Jackson 库解析 jsON步骤 3: 添

Java 字符数组转字符串的常用方法

《Java字符数组转字符串的常用方法》文章总结了在Java中将字符数组转换为字符串的几种常用方法,包括使用String构造函数、String.valueOf()方法、StringBuilder以及A... 目录1. 使用String构造函数1.1 基本转换方法1.2 注意事项2. 使用String.valu

python修改字符串值的三种方法

《python修改字符串值的三种方法》本文主要介绍了python修改字符串值的三种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录第一种方法:第二种方法:第三种方法:在python中,字符串对象是不可变类型,所以我们没办法直接

JAVA中整型数组、字符串数组、整型数和字符串 的创建与转换的方法

《JAVA中整型数组、字符串数组、整型数和字符串的创建与转换的方法》本文介绍了Java中字符串、字符数组和整型数组的创建方法,以及它们之间的转换方法,还详细讲解了字符串中的一些常用方法,如index... 目录一、字符串、字符数组和整型数组的创建1、字符串的创建方法1.1 通过引用字符数组来创建字符串1.2

C#中字符串分割的多种方式

《C#中字符串分割的多种方式》在C#编程语言中,字符串处理是日常开发中不可或缺的一部分,字符串分割是处理文本数据时常用的操作,它允许我们将一个长字符串分解成多个子字符串,本文给大家介绍了C#中字符串分... 目录1. 使用 string.Split2. 使用正则表达式 (Regex.Split)3. 使用

Java中JSON字符串反序列化(动态泛型)

《Java中JSON字符串反序列化(动态泛型)》文章讨论了在定时任务中使用反射调用目标对象时处理动态参数的问题,通过将方法参数存储为JSON字符串并进行反序列化,可以实现动态调用,然而,这种方式容易导... 需求:定时任务扫描,反射调用目标对象,但是,方法的传参不是固定的。方案一:将方法参数存成jsON字

RabbitMQ练习(AMQP 0-9-1 Overview)

1、What is AMQP 0-9-1 AMQP 0-9-1(高级消息队列协议)是一种网络协议,它允许遵从该协议的客户端(Publisher或者Consumer)应用程序与遵从该协议的消息中间件代理(Broker,如RabbitMQ)进行通信。 AMQP 0-9-1模型的核心概念包括消息发布者(producers/publisher)、消息(messages)、交换机(exchanges)、