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;}};

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

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

相关文章

解决Android Studio安卓开发写入文件问题

有很多小伙伴想把文件写进安卓系统储存失败&#xff0c;类似下面的代码 val file File("account.txt")val writer BufferedWriter(FileWriter(file))writer.use {it.write(username "," password)} 用java方式写入读出文件但是显示成功但是找不到文件…

Linux--自主编写shell

目录 准备知识 shell原理 shell与用户互动的过程 实现shell 0.用到的头文件和宏定义 1.首先我们需要自己输出一个命令行 2.获取用户命令行字符 3.命令行字符串分割 4.执行命令 5.设置循环 6.检测内建命令 7.完善细节--获取工作目录而非路径 准备知识 Linux--环境…

Linux系统安全与应用【二】

目录 1.开关机安全控制 1.2 实例&#xff1a;GRUB 菜单设置密码 2.终端登录安全控制 2.1 限制root只在安全终端登录 ​3.弱口令检测 3.1 Joth the Ripper,JR​编辑 4.网络端口扫描 4.1 nmap命令 1.开关机安全控制 1.1 GRUB限制 限制更改GRUB引导参数 通常情况下在系统…

类和对象【三】析构函数和拷贝构造函数

文章目录 析构函数析构函数的定义析构函数的作用主要作用次要作用 析构函数的特点 拷贝构造函数拷贝构造函数的定义拷贝构造函数的作用主要作用次要作用 拷贝构造函数的特点浅拷贝和深拷贝浅拷贝深拷贝 拷贝构造函数的调用场景 析构函数 析构函数的定义 析构函数(destructor) …

mybatis基本使用

文章目录 1. mybatis2. 基本使用(1) maven坐标(2) 配置文件编写(3) 数据库操作(4) 注解查询 2. 基本配置(1) 读取外部配置文件(2) mapper映射 3. 映射文件查询删除/修改/新增 动态sql 1. mybatis MyBatis 是一款优秀的持久层框架&#xff0c;它支持自定义 SQL、存储过程以及高…

使用 Gradio 的“热重载”模式快速开发 AI 应用

在这篇文章中&#xff0c;我将展示如何利用 Gradio 的热重载模式快速构建一个功能齐全的 AI 应用。但在进入正题之前&#xff0c;让我们先了解一下什么是重载模式以及 Gradio 为什么要采用自定义的自动重载逻辑。如果你已熟悉 Gradio 并急于开始构建&#xff0c;请直接跳转到第…

记录些RAG中Chunk切分方法

非结构化数据 在处理非结构化数据时&#xff0c;文本切分策略的选择至关重要&#xff0c;以保持信息完整性和提高检索效率。以下是一些有效的切分方法&#xff1a; 固定长度切分&#xff1a;将文本按照固定的字数或词数进行切分&#xff0c;例如每个文档切分成300个字或300个…

【Camera KMD ISP SubSystem笔记】Request 流转与Bubble机制

ISP中断类型 SOF: 一帧图像数据开始传输 EOF: 一帧图像数据传输完成 REG_UPDATE: ISP寄存器更新完成(每个reg group都有独立的这个中断) EPOCH: ISP某一行结尾(默认20)就会产生此中断 BUFFER DONE: 一帧图像数据ISP完全写到DDR了 管理Isp request的几个List st…

代码随想录:二叉树22-24

目录 700.二叉搜索树的搜索 题目 代码&#xff08;二叉搜索树迭代&#xff09; 代码&#xff08;二叉搜索树递归&#xff09; 代码&#xff08;普通二叉树递归&#xff09; 代码&#xff08;普通二叉树迭代&#xff09; 98.验证二叉搜索树 题目 代码&#xff08;中序递…

oracle rman restore database的时候报错RMAN-06023: 没有找到数据文件1的副本来还原

一 问题描述 在oracle异地备份恢复测试数据库上执行restore database的时候报错&#xff1a; RMAN-06023: 没有找到数据文件1的副本来还原 可是我看备份明明都是存在的&#xff0c;而且已经执行了catalog start with命令。 有点奇怪的是catalog start with的时候&#xff0c…

4.10 海思SS928开发 - uboot开发 - 环境变量使用注意

4.10 uboot开发 - 环境变量使用注意 更新 uboot 镜像文件时&#xff0c;环境变量相关工具也需要更新。uboot 镜像文件与环境变量工具如果不对应的话&#xff0c;可能会导致莫名其妙的问题。更新 uboot 镜像文件时&#xff0c;最好将储存在磁盘上的环境变量擦除。因为当磁盘上存…

牛客NC143 矩阵乘法【中等 矩阵 C++/Java/Go/PHP】

题目 题目链接&#xff1a; https://www.nowcoder.com/practice/bf358c3ac73e491585943bac94e309b0 思路 矩阵算法在图像处理、神经网络、模式识别等领域有着广泛的用途。在矩阵乘法中&#xff0c;A矩阵和B矩阵可以做乘法运算必须满足A矩阵的列的数量等于B矩阵的行的数量。运算…

d13(126-129)-勇敢开始Java,咖啡拯救人生

目录 Arrays类 数组中存储对象时 排序 在要比较的类中public class 类名 implements Comparable <类名> Comparator JDK8新特性&#xff1a;Lambda表达式 Lambda表达式的省略写法 方法引用 静态方法引用 实例方法引用 特定类型的方法引用 构造器引用 医院挂号系…

FANUC机器人SOCKET连接指令编写

一、创建一个.KL文件编写连接指令 创建一个KL文本来编写FANUC机器人socket连接指令 二、KAREL指令代码 fanuc机器人karel编辑器编辑的karel代码如下&#xff1a; PROGRAM SM_CON %COMMENT SOCKET连接 %STACKSIZE 4000 --堆栈大小 %INCLUDE klevccdfVAR status,data_type,in…

【draw.io的使用心得介绍】

&#x1f308;个人主页: 程序员不想敲代码啊 &#x1f3c6;CSDN优质创作者&#xff0c;CSDN实力新星&#xff0c;CSDN博客专家 &#x1f44d;点赞⭐评论⭐收藏 &#x1f91d;希望本文对您有所裨益&#xff0c;如有不足之处&#xff0c;欢迎在评论区提出指正&#xff0c;让我们共…

OpenHarmony实战开发-使用SmartPerf-Host分析应用性能

简介 SmartPerf-Host是一款深入挖掘数据、细粒度展示数据的性能功耗调优工具&#xff0c;可采集CPU调度、频点、进程线程时间片、堆内存、帧率等数据&#xff0c;采集的数据通过泳道图清晰地呈现给开发者&#xff0c;同时通过GUI以可视化的方式进行分析。该工具当前为开发者提…

Swift 中的条件语句:if 和 else

在 Swift 编程语言中&#xff0c;条件语句 if 和 else 是控制程序流程的重要工具。它们允许我们根据不同的条件执行不同的代码块&#xff0c;从而实现更灵活的程序逻辑。 if 语句 if 语句用于执行一个代码块&#xff0c;当指定的条件为真时。其基本语法如下&#xff1a; if …

2024第十五届蓝桥杯网络安全赛项WriteUp

欢迎关注公众号【Real返璞归真】回复【蓝桥杯2024】获取完整题目附件。 排名 安全知识 错1个选择题&#xff0c;题目说的不清楚&#xff0c;没搞懂题意。肯定不能用eval。错了理论题有点遗憾。 没想到这题前端是要解析json数据&#xff0c;排除CD选了A&#xff0c;结果发现正…

每日一题(力扣45):跳跃游戏2--贪心

由于题目已经告诉了我们一定可以跳到&#xff0c;所以我们只需去考虑前进最快的方法。即 判断当前下一步能跳的各个位置中&#xff0c;哪个能带你去去向最远的地方&#xff08;why&#xff1f; 因为其他位置所能提供的最大范围都没最远那个大&#xff0c;所以最远的那个已经可以…

嵌入式Linux学习——Ubantu初体验

Ubuntu 和Windows 的最大差别 Windows中的每一个分区都对应着一个盘符&#xff0c;盘符下可以存放目录与文件&#xff0c;而在Ubantu中没有盘符的概念&#xff0c;只有目录结构。实际上不同的目录可能挂载在不同的分区之下&#xff0c;如果想要查看当前目录位于磁盘的哪个分区…