LeetCode算法题-Backspace String Compare(Java实现)
这是悦乐书的第327次更新,第350篇原创
01 看题和准备
今天介绍的是LeetCode算法题中Easy级别的第197题(顺位题号是844)。给定两个字符串S和T,如果两个字符串都输入到空文本编辑器中并且相等,则返回true。 #表示退格符。例如:
输入:S =“ab#c”,T =“ad#c”
输出:true
说明:S和T都变为“ac”。
输入:S =“ab ##”,T =“c#d#”
输出:true
说明:S和T都变为“”。
输入:S =“a ## c”,T =“#a#c”
输出:true
说明:S和T都变为“c”。
输入:S =“a#c”,T =“b”
输出:false
说明:S变为“c”而T变为“b”。
注意:
1 <= S.length <= 200
1 <= T.length <= 200
S和T仅包含小写字母和“#”字符。
跟进:能在O(N)时间和O(1)空间解决它吗?
本次解题使用的开发工具是eclipse,jdk使用的版本是1.8,环境是win7 64位系统,使用Java语言编写和测试。
02 第一种解法
题目的意思是遇到一个#号就往前去掉一个字母,最后比较两个字符串是否相等。因为是往前去掉字母,所以可以从后往前处理。
解题思路就是从后往前遍历字符串中的字符,统计遇到的#号个数,直到遇上字母为止,然后跳过相同数量(前面统计的#号的数量)的字母,然后累加字符,变成一个新的字符串,将另外一个字符串也按照同样的方式处理。
处理字符串S和T的思路、过程都一样,因此将其抽离出来单独作为一个方法使用。
public boolean backspaceCompare(String S, String T) {
return rebuild(S).equals(rebuild(T));
}
public String rebuild(String str){
int n = str.length(), count = 0;
String newStr = "";
for (int i=n-1; i >= 0; i--) {
char ch = str.charAt(i);
if (ch == '#') {
count++;
} else {
if (count > 0) {
count--;
} else {
newStr += ch;
}
}
}
return newStr;
}
03 第二种解法
利用栈。
和上面第一种的解法类似,也是转换成新的字符串,只不过是使用栈来实现,借助其先进后出的特性。
依旧是遍历字符串中的字符,如果当前字符不是#号,就入栈;如果遇到#号,就需要回退一个字符,只需要将栈顶的元素出栈即可,但是需要先判断栈中是否包含元素。
public boolean backspaceCompare2(String S, String T) {
return rebuildUseStack(S).equals(rebuildUseStack(T));
}
public String rebuildUseStack(String str) {
Stack<Character> stack = new Stack<Character>();
for (char ch : str.toCharArray()) {
if (ch != '#') {
stack.push(ch);
} else if (!stack.isEmpty()) {
stack.pop();
}
}
return String.valueOf(stack);
}
04 第三种解法
利用双指针。
上面两种解法都将原字符串替换成了新的字符串去比较是否相等,我们也可以不使用这种方法,借助双指针,通过依次比较对应字符来实现。
定义两个指针,从后往前遍历,找到需要比较的字符的索引位置(#号和对应要去掉的字母排除),比较对应的字符是否相等,如果字符不相等或者其中有一个指针先为0了,可以直接返回false。
public boolean backspaceCompare3(String S, String T) {
int i = S.length()-1, j = T.length()-1;
while (i >= 0 || j >= 0) {
i = helper(S, i);
j = helper(T, j);
// 判断当前i和j对应的字符是否相等
if (i >= 0 && j >= 0 && S.charAt(i) != T.charAt(j)) {
return false;
}
// 如果i或者j小于0时,判断两者是否同时小于0
if (i < 0 || j < 0) {
return i == j;
}
// 继续向前
i--;
j--;
}
return true;
}
/**
* 找到下一个需要进行字符比较的索引位置
* @param str
* @param index
* @return
*/
public int helper(String str, int index){
int count = 0;
while (index >= 0) {
if (str.charAt(index) == '#') {
// 对遇上的#号记数
count++;
index--;
} else if (count > 0) {
// 过滤掉#号前面对应个数的字母
count--;
index--;
} else {
break;
}
}
return index;
}
05 小结
算法专题目前已日更超过五个月,算法题文章197+篇,公众号对话框回复【数据结构与算法】、【算法】、【数据结构】中的任一关键词,获取系列文章合集。
以上就是全部内容,如果大家有什么好的解法思路、建议或者其他问题,可以下方留言交流,点赞、留言、转发就是对我最大的回报和支持!
LeetCode算法题-Backspace String Compare(Java实现)的更多相关文章
- LeetCode算法题-Rotate String(Java实现)
这是悦乐书的第317次更新,第338篇原创 在开始今天的算法题前,说几句,今天是世界读书日,推荐两本书给大家,<终身成长>和<禅与摩托车维修艺术>,值得好好阅读和反复阅读. 0 ...
- LeetCode算法题-Reverse String(Java实现)
这是悦乐书的第205次更新,第217篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第73题(顺位题号是344).编写一个以字符串作为输入并返回字符串的函数.例如: 输入: ...
- LeetCode算法题-Repeated String Match(Java实现)
这是悦乐书的第289次更新,第307篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第156题(顺位题号是686).给定两个字符串A和B,找到A必须重复的最小次数,使得B是 ...
- LeetCode算法题-Construct String from Binary Tree(Java实现)
这是悦乐书的第273次更新,第288篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第141题(顺位题号是606).构造一个字符串,该字符串由二叉树中的括号和整数组成,并具 ...
- LeetCode算法题-Reverse String II(Java实现)
这是悦乐书的第256次更新,第269篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第123题(顺位题号是541).给定一个字符串和一个整数k,你需要反转从字符串开头算起的 ...
- LeetCode算法题-Rotated Digits(Java实现)
这是悦乐书的第316次更新,第337篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第185题(顺位题号是788).如果一个数字经过180度旋转后,变成了一个与原数字不同的 ...
- LeetCode算法题-Baseball Game(Java实现)
这是悦乐书的第288次更新,第305篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第156题(顺位题号是682).你现在是棒球比赛点记录器.给定一个字符串列表,每个字符串 ...
- LeetCode算法题-Detect Capital(Java实现)
这是悦乐书的第251次更新,第264篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第118题(顺位题号是520).给定一个单词,你需要判断其中大写字母的使用是否正确.当下 ...
- LeetCode算法题-Relative Ranks(Java实现)
这是悦乐书的第248次更新,第261篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第115题(顺位题号是506).根据N名运动员的得分,找到他们的相对等级和得分最高的三个 ...
随机推荐
- [易学易懂系列|rustlang语言|零基础|快速入门|(12)|Enums枚举]
[易学易懂系列|rustlang语言|零基础|快速入门|(12)] 有意思的基础知识 Enums 今天我们来讲讲枚举. 在数学和计算机科学理论中,一个集的枚举是列出某些有穷序列集的所有成员的程序,或者 ...
- ASP.NET 中 取得 Repeater 里的checkbox值
前言:这两天在维护ASP.NET的项目,需要做一个checkbox来选择数据进行导出,下面提供两种解决思路 1.ASP:CheckBox asp:CheckBox自带控件,没有Value值 <a ...
- AI换脸教程:DeepFaceLab使用教程(2.训练及合成)
如果前期工作已经准备完毕(DeepFaceLab下载(https://www.deepfacelabs.com/list-5-1.html),然后安装相应的显卡驱动,DeepFaceLab使用教程(1 ...
- java课堂动手测试
课堂实验3 一个Java类文件中真的只能有一个公有类吗? 经过测试,当含有两个public 类时会报错,不能执行,假如删除第二个public则可以正常生成,说明一个java文件只能有一个公有类. 课 ...
- sevlet
https://blog.csdn.net/Mithrandir_One/article/details/52900425 大家现在做的比较多的基本上就是 web 应用.所以一定要把 sevlet 及 ...
- c语言模块化编程
C语言模块化编程(封装) 模块即是一个.c 文件和一个.h 文件的结合,头文件(.h)中是对于该模块接口的声明.模块化的实现方法和实质:将一个功能模块的代码单独编写成一个.c文件,然后把该模块的接口函 ...
- c++常见函数记录
1.bitsset 模板,可以操作二进制字符串,转化成数字等 2.swap()交换函数,将a,b的值交换 3.stringstream类用于字符串和其他类型的转换,操作方便 4.stx,tr1. 5. ...
- python+selenium封装UI自动化框架
seleinum框架 框架的思想: 解决我们测试过程中的问题:大量的重复步骤,用自动化来实现 1)配置和程序的分离 2)测试数据和程序的分离 3)不懂编程的人员可以方便使用:使用的 ...
- php将base64字符串转换为图片
昨天用一个js插件 [链接]: http://www.erdangjiade.com/js/910.html 实行了图片裁剪并预览,不过它生产的图片资源是一个base64字符串,不好保存后来在网上找到 ...
- #419 Div2 Problem C Karen and Game (贪心 && 暴力)
题目链接:http://codeforces.com/contest/816/problem/C 题意 :给出一个 n*m 的变化后的矩阵,变化前矩阵的元素全是0,变化的规则是选择其中的一行或者一列将 ...