6.比较含退格的字符串(力扣字符串)(两种解法:字符串操作,栈)

2024-04-28 11:28

本文主要是介绍6.比较含退格的字符串(力扣字符串)(两种解法:字符串操作,栈),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

题目链接

法一:普通字符串操作

法二:栈操作


题目链接

. - 力扣(LeetCode)

法一:普通字符串操作

用len1记录目前s的字符个数,len2记录目前t的字符个数

如果不是#,则s[len1] = s[i]

如果是#,则len1--(也就是#不放入,且上一个放入的字符会被下一个字符覆盖)

//法一:普通字符串操作
class Solution
{
public:bool backspaceCompare(string s, string t){if (s.size() == 0 && t.size() == 0)return true;int len1 = 0, len2 = 0;for (int i = 0; i < s.size(); i++){if (s[i] == '#'){//如果是#,则len1--(也就是#不放人,且上一个放入的字符会被下一个字符覆盖)if (len1 > 0)len1--;}else{//如果不是#,则s[len1] = s[i]s[len1] = s[i];len1++;}}s[len1] = '\0';for (int i = 0; i < t.size(); i++){if (t[i] == '#'){if (len2 > 0)len2--;}else{t[len2] = t[i];len2++;}}t[len2] = '\0';cout << s << endl << t << endl;if (len1 != len2)return false;if (len1 == 0 && len2 == 0)return true;int j = 0;for (int i = 0; i < len1; i++, j++){if (s[i] != t[j])return false;}return true;}
};

法二:栈操作

如果不是#,则将该元素入栈

如果是#,弹出栈顶(#前面的字符被弹出),注意:栈为空的时候不可弹栈

最后将s和t改为栈内元素,注意栈的后进先出的特性


//法二:栈class Solution{public:bool backspaceCompare(string s, string t){if (s.size() == 0 && t.size() == 0)return true;stack<char>st1, st2;int len1, len2;int count = s.size();//记录s最后的字符个数for (int i = 0; i < s.size(); i++){if (s[i] != '#'){//如果不是#,则将该元素入栈                 st1.push(s[i]);}else{//如果是#,弹出栈顶,注意:栈为空的时候不可弹栈if (!st1.empty()){//减去# 和 #前面的那个字符占的字符数count -= 2;st1.pop();}else{//减去#占的字符数count--;}}}if (count == 0){s = "";len1 = 0;}else{//栈后进先出,所以倒着更新for (int i = count - 1; i >= 0; i--){s[i] = st1.top();st1.pop();}len1 = count;}count = t.size();for (int i = 0; i < t.size(); i++){if (t[i] != '#'){st2.push(t[i]);}else{if (!st2.empty()){//减去# 和 #前面的那个字符占的字符数count -= 2;st2.pop();}else{//减去 # 占的字符数count--;}}}if (len1 != count)return false;if (count == 0){t = "";len2 = 0;}else{for (int i = count - 1; i >= 0; i--){t[i] = st2.top();st2.pop();}len2 = count;}if (len1 != len2)return false;if (len1 == 0 && len2 == 0)return true;int j = 0;for (int i = 0; i < len1; i++, j++){if (s[i] != t[j])return false;}return true;}};

这篇关于6.比较含退格的字符串(力扣字符串)(两种解法:字符串操作,栈)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Java controller接口出入参时间序列化转换操作方法(两种)

《Javacontroller接口出入参时间序列化转换操作方法(两种)》:本文主要介绍Javacontroller接口出入参时间序列化转换操作方法,本文给大家列举两种简单方法,感兴趣的朋友一起看... 目录方式一、使用注解方式二、统一配置场景:在controller编写的接口,在前后端交互过程中一般都会涉及

Java中的StringBuilder之如何高效构建字符串

《Java中的StringBuilder之如何高效构建字符串》本文将深入浅出地介绍StringBuilder的使用方法、性能优势以及相关字符串处理技术,结合代码示例帮助读者更好地理解和应用,希望对大家... 目录关键点什么是 StringBuilder?为什么需要 StringBuilder?如何使用 St

使用Java将各种数据写入Excel表格的操作示例

《使用Java将各种数据写入Excel表格的操作示例》在数据处理与管理领域,Excel凭借其强大的功能和广泛的应用,成为了数据存储与展示的重要工具,在Java开发过程中,常常需要将不同类型的数据,本文... 目录前言安装免费Java库1. 写入文本、或数值到 Excel单元格2. 写入数组到 Excel表格

Python中pywin32 常用窗口操作的实现

《Python中pywin32常用窗口操作的实现》本文主要介绍了Python中pywin32常用窗口操作的实现,pywin32主要的作用是供Python开发者快速调用WindowsAPI的一个... 目录获取窗口句柄获取最前端窗口句柄获取指定坐标处的窗口根据窗口的完整标题匹配获取句柄根据窗口的类别匹配获取句

Python位移操作和位运算的实现示例

《Python位移操作和位运算的实现示例》本文主要介绍了Python位移操作和位运算的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1. 位移操作1.1 左移操作 (<<)1.2 右移操作 (>>)注意事项:2. 位运算2.1

C#使用StackExchange.Redis实现分布式锁的两种方式介绍

《C#使用StackExchange.Redis实现分布式锁的两种方式介绍》分布式锁在集群的架构中发挥着重要的作用,:本文主要介绍C#使用StackExchange.Redis实现分布式锁的... 目录自定义分布式锁获取锁释放锁自动续期StackExchange.Redis分布式锁获取锁释放锁自动续期分布式

Python ZIP文件操作技巧详解

《PythonZIP文件操作技巧详解》在数据处理和系统开发中,ZIP文件操作是开发者必须掌握的核心技能,Python标准库提供的zipfile模块以简洁的API和跨平台特性,成为处理ZIP文件的首选... 目录一、ZIP文件操作基础三板斧1.1 创建压缩包1.2 解压操作1.3 文件遍历与信息获取二、进阶技

Windows 上如果忘记了 MySQL 密码 重置密码的两种方法

《Windows上如果忘记了MySQL密码重置密码的两种方法》:本文主要介绍Windows上如果忘记了MySQL密码重置密码的两种方法,本文通过两种方法结合实例代码给大家介绍的非常详细,感... 目录方法 1:以跳过权限验证模式启动 mysql 并重置密码方法 2:使用 my.ini 文件的临时配置在 Wi

Java中字符串转时间与时间转字符串的操作详解

《Java中字符串转时间与时间转字符串的操作详解》Java的java.time包提供了强大的日期和时间处理功能,通过DateTimeFormatter可以轻松地在日期时间对象和字符串之间进行转换,下面... 目录一、字符串转时间(一)使用预定义格式(二)自定义格式二、时间转字符串(一)使用预定义格式(二)自

Java字符串操作技巧之语法、示例与应用场景分析

《Java字符串操作技巧之语法、示例与应用场景分析》在Java算法题和日常开发中,字符串处理是必备的核心技能,本文全面梳理Java中字符串的常用操作语法,结合代码示例、应用场景和避坑指南,可快速掌握字... 目录引言1. 基础操作1.1 创建字符串1.2 获取长度1.3 访问字符2. 字符串处理2.1 子字