当前位置: 首页 > news >正文

红古微信网站建设盱眙网站建设

红古微信网站建设,盱眙网站建设,html空白模板下载,人才网站建设报告每日一题(LeetCode)----数组–移除元素(四) 1.题目([844. 比较含退格的字符串](https://leetcode.cn/problems/sqrtx/)) 给定 s 和 t 两个字符串,当它们分别被输入到空白的文本编辑器后,如果两者相等&…

每日一题(LeetCode)----数组–移除元素(四)

1.题目([844. 比较含退格的字符串](https://leetcode.cn/problems/sqrtx/))

给定 st 两个字符串,当它们分别被输入到空白的文本编辑器后,如果两者相等,返回 true# 代表退格字符。

**注意:**如果对空文本输入退格字符,文本继续为空。

示例 1:

输入:s = "ab#c", t = "ad#c"
输出:true
解释:s 和 t 都会变成 "ac"。

示例 2:

输入:s = "ab##", t = "c#d#"
输出:true
解释:s 和 t 都会变成 ""。

示例 3:

输入:s = "a#c", t = "b"
输出:false
解释:s 会变成 "c",但 t 仍然是 "b"。

提示:

  • 1 <= s.length, t.length <= 200
  • st 只含有小写字母以及字符 '#'

进阶:

  • 你可以用 O(n) 的时间复杂度和 O(1) 的空间复杂度解决该问题吗?

2.解题思路

思路一: 重构字符串(单指针)

1.先将两个字符串中的退格字符和应该被删除的字符去除掉

我们用一个变量来存已经遍历到的退格字符的数量

然后我们从后向前遍历这两个字符串

如果遍历到的是退格字符,那么删除退格字符,然后记录已经遍历到退格字符的数量的变量进行加一操作

如果遍历到的是字符,那我们看记录已经遍历到退格字符的数量的变量是否大于0

如果大于0删除当前遍历到的字符,记录已经遍历到退格字符的数量的变量进行减一操作

如果小于0,那么不进行操作,进行向前遍历

2.然后将两个字符串进行比较

思路二: 重构字符串(栈)

最容易想到的方法是将给定的字符串中的退格符和应当被删除的字符都去除,还原给定字符串的一般形式。然后直接比较两字符串是否相等即可。

具体地,我们用栈处理遍历过程,每次我们遍历到一个字符:

如果它是退格符,那么我们将栈顶弹出;

如果它是普通字符,那么我们将其压入栈中。

原作者:力扣官方题解
链接:https://leetcode.cn/problems/backspace-string-compare/

3.写出代码

思路一的代码:

class Solution {
public:bool backspaceCompare(string s, string t) {int length1 = s.size();int length2 = t.size();int sum1 = 0;int sum2 = 0;for (int i = length1 - 1; i >= 0; i--) {if (s.size() == 0) {break;}if (s[i] == '#') {s.erase(i, 1);sum1++;}else {if (sum1 > 0) {s.erase(i, 1);sum1--;}}}for (int i = length2 - 1; i >= 0; i--) {if (t.size() == 0) {break;}if (t[i] == '#') {t.erase(i, 1);sum2++;}else {if (sum2 > 0) {t.erase(i, 1);sum2--;}}}//进行比较if (s == t) {return true;}else {return false;}}
};

思路二的代码:

class Solution {
public:bool backspaceCompare(string S, string T) {return build(S) == build(T);}string build(string str) {string ret;for (char ch : str) {if (ch != '#') {ret.push_back(ch);} else if (!ret.empty()) {ret.pop_back();}}return ret;}
};
原作者:力扣官方题解
链接:https://leetcode.cn/problems/backspace-string-compare/
http://www.yayakq.cn/news/546125/

相关文章:

  • 网站推广的工具网站建设服务亿企网络
  • 网站后台功能模块手机怎么看网页源代码
  • 家里的电脑怎样做网站赚钱wordpress输出文章id
  • 本地的营销网站建设哪里可以做网站的
  • 永州网站建设如何百度推广费用多少
  • 如何做地方网站app安装下载官网
  • 北京市违法建设投诉网站行业网站网址
  • 盐城市建设银行网站中国最好的域名注册网站
  • 单纯做网站的公司竞价被恶意点击怎么办
  • 诸城做网站的网络营销工具的分类
  • 徐州开发的网站青岛做网站建设价格
  • wordpress网站主修改网站链接如何做二维码
  • 中国建设银行北京分行官网站什么网站能代做预算
  • 企业网站设计html深圳建设网站的公司哪家好
  • 重要的网站建设wordpress文章排行榜
  • 建设投资公司网站网站域名空间费用
  • 免费建立个人app网站集团网站 wordpress
  • 校园网站建设的意义电子商务网站预算模板
  • 住房和城乡建设局部网站怎么才能提高网站点击量 免费
  • 抚州市建设局网站公司起名大全2021最新版的免费
  • 企业网站建设注意点如何做网站标题
  • 网站首页命名网页传奇游戏排行榜比亚迪
  • 做网站虚拟主机哪里有邯郸seo
  • 南通网站建设排名公司哪家好网站变宽屏怎么做
  • 网站建设 数据库管理做一个网页版面多少钱
  • 做网站的公司哪家强移动互联网包含( )三个方面
  • 单页面网站 seo建设网站的HTML代码
  • 山东省建设安全生产协会网站西安网站开发托管代运营
  • 那间公司做网站好sem优化
  • 刚注册在域名可以自己做网站吗网页编辑软件有哪些?