当前位置:网站首页>LeetCode刷题——去除重复字母#316#Medium
LeetCode刷题——去除重复字母#316#Medium
2022-07-02 12:04:00 【喷火龙与水箭龟】
去除重复字母的思路探讨与源码
去除重复字母的题目如下图,该题属于字符串类和栈搜索类型的题目,主要考察对于字符串搜索方法的使用和栈结构的理解。本文的题目作者想到2种方法,分别是贪心单调栈方法和哈希表方法,其中贪心单调栈方法使用Java进行编写,而哈希表方法使用Python进行编写,当然这可能不是最优的解法,还希望各位大佬给出更快的算法。
本人认为该题目可以使用贪心单调栈方法的思路进行解决,首先初始化一个长度26位的布尔类型的数组并赋值。然后初始化一个字符串列表,开始遍历循环,将当前下标对应的字符拿出来,将它和小写字母a进行比较,如果没有遍历过,那么就进行搜索,如果满足条件就将布尔类型的值赋值为false后删除这个字符,即认为是重复。再将结果插入到字符串列表里,以此逻辑循环并直到结束后返回结果。那么按照这个思路我们的Java代码如下:
#喷火龙与水箭龟
class Solution {
public String removeDuplicateLetters(String s) {
boolean[] numCharArr = new boolean[26];
int[] num = new int[26];
for (int ir = 0; ir < s.length(); ir++) {
num[s.charAt(ir) - 'a']++;
}
StringBuffer sb = new StringBuffer();
for (int i = 0; i < s.length(); i++) {
char ch = s.charAt(i);
if (! numCharArr[ch - 'a']) {
while (sb.length() > 0 && sb.charAt(sb.length() - 1) > ch) {
if (num[sb.charAt(sb.length() - 1) - 'a'] > 0) {
numCharArr[sb.charAt(sb.length() - 1) - 'a'] = false;
sb.deleteCharAt(sb.length() - 1);
} else {
break;
}
}
numCharArr[ch - 'a'] = true;
sb.append(ch);
}
num[ch - 'a'] -= 1;
}
return sb.toString();
}
}
显然,我们看到贪心单调栈方法的效果还可以,同时还可以使用哈希表的方法解决。首先初始化一个计数器和一个队列,计数器可以得到每个字符出现的次数,然后开始遍历字符串,将当前字符的数量减去1,并且判断字符是否在列表里,如果是就继续下一轮循环,如果不是就会循环遍历列表,把列表的元素抛出后,将当前字符加入到列表里面,最终直到循环结束并返回列表的所有元素的和,即最终的字符串。所以按照这个思路就可以解决,下面是Python代码:
#喷火龙与水箭龟
from collections import Counter
class Solution:
def removeDuplicateLetters(self, s):
listStack=[]
sk = Counter(s)
for jr in s:
sk[jr] = sk[jr]-1
if(jr in listStack):
continue
while listStack and listStack[-1] > jr and sk[listStack[-1]] > 0:
listStack.pop()
listStack.append(jr)
return ''.join(listStack)
从结果来说Java版本的贪心单调栈的效率还可以,而Python版本的哈希表方法的速度比较一般,但应该是有更多的方法可以进一步提速的,希望朋友们能够多多指教,非常感谢。
边栏推荐
- IE 浏览器正式退休
- 15_Redis_Redis.conf详解
- Yolov5 code reproduction and server operation
- [noi Simulation Competition] scraping (dynamic planning)
- Tidb data migration scenario overview
- 07_哈希
- The past and present lives of visual page building tools
- 16_Redis_Redis持久化
- vChain: Enabling Verifiable Boolean Range Queries over Blockchain Databases(sigmod‘2019)
- 你不知道的Set集合
猜你喜欢
随机推荐
牛客练习赛101
二叉树的遍历方式主要有:先序遍历、中序遍历、后序遍历、层次遍历。先序、中序、后序其实指的是父节点被访问的次序。若在遍历过程中,父节点先于它的子节点被访问,就是先序遍历;
Mavn 搭建 Nexus 私服
Btrace- (bytecode) dynamic tracking tool
[solution] educational codeforces round 82
Solve the problem that El radio group cannot be edited after echo
学习使用php将时间戳转换为大写日期的方法代码示例
15_ Redis_ Redis. Conf detailed explanation
Niuke Practice 101
Leetcode - Search 2D matrix
TiDB跨数据中心部署拓扑
11_Redis_Hyperloglog_命令
如何用 Sysbench 测试 TiDB
【网络安全】网络资产收集
AtCoder Beginner Contest 254
Infra11199 database system
02_线性表_顺序表
Download blender on Alibaba cloud image station
How to find a sense of career direction
哈夫曼树:(1)输入各字符及其权值(2)构造哈夫曼树(3)进行哈夫曼编码(4)查找HC[i],得到各字符的哈夫曼编码