网站首页 > java教程 正文
题目
给出由小写字母组成的字符串 S,重复项删除操作会选择两个相邻且相同的字母,并删除它们。
在 S 上反复执行重复项删除操作,直到无法继续删除。
在完成所有重复项删除操作后返回最终的字符串。答案保证唯一。
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/remove-all-adjacent-duplicates-in-string
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
代码
public class DayCode {
public static void main(String[] args) {
String s = "abbaca";
String ans = new DayCode().removeDuplicates(s);
System.out.println("ans is " + ans);
}
/**
* 时间复杂度O(n)
* 空间复杂度O(n)
* https://leetcode-cn.com/problems/remove-all-adjacent-duplicates-in-string/
* @param S
* @return
*/
public String removeDuplicates(String S) {
StringBuilder stringBuilder = new StringBuilder();
int n = S.length();
Deque<Character> deque = new ArrayDeque<>(n);
for (int i = 0; i < n; i++) {
if (deque.isEmpty() || (!deque.isEmpty() && S.charAt(i) != deque.peek())) {
deque.push(S.charAt(i));
} else {
while (!deque.isEmpty() && S.charAt(i) == deque.peek()) {
deque.pop();
}
}
}
while (!deque.isEmpty()) {
stringBuilder.append(deque.pop());
}
return stringBuilder.reverse().toString();
}
}
总结
* 这是一道简单题,重拳出击!题目含义容易理解。采用栈的数据结构,可以帮助简化问题,对栈进行添加,移除操作,最后返回字符串即可。
* 坚持每日一题,加油!
猜你喜欢
- 2024-10-22 「是时候升级Java11了」 JDK11优势和JDK选择
- 2024-10-22 一文读懂关于Java如何找出两个列表之间的新增和删除元素
- 2024-10-22 JAVA 面试高频提问知识点之:SET、LIST 和 MAP 的区别
- 2024-10-22 Java常规操作新增,更新,删除(java常规操作新增,更新,删除什么意思)
- 2024-10-22 JAVA全栈CMS系统Vue无限级分类拖拽增改查批量删除7
- 2024-10-22 sed命令之删除匹配行的详细介绍(sed命令删除指定内容范围)
- 2024-10-22 # Redis 入门到精通(七)-- redis 删除策略
- 2024-10-22 【Java面试题】List如何一边遍历,一边删除?
- 2024-10-22 Redis03——Redis是如何删除你的数据的
- 2024-10-22 java 如何破坏双亲委派模型,卸载类?
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- java反编译工具 (77)
- java反射 (57)
- java接口 (61)
- java随机数 (63)
- java7下载 (59)
- java数据结构 (61)
- java 三目运算符 (65)
- java对象转map (63)
- Java继承 (69)
- java字符串替换 (60)
- 快速排序java (59)
- java并发编程 (58)
- java api文档 (60)
- centos安装java (57)
- java调用webservice接口 (61)
- java深拷贝 (61)
- 工厂模式java (59)
- java代理模式 (59)
- java.lang (57)
- java连接mysql数据库 (67)
- java重载 (68)
- java 循环语句 (66)
- java反序列化 (58)
- java时间函数 (60)
- java是值传递还是引用传递 (62)
本文暂时没有评论,来添加一个吧(●'◡'●)