1 去除重复字母
发布日期:2021-05-10 01:35:03 浏览次数:18 分类:精选文章

本文共 1345 字,大约阅读时间需要 4 分钟。

316. 去除重复字母给你一个字符串 s ,请你去除字符串中重复的字母,使得每个字母只出现一次。需保证 返回结果的字典序最小(要求不能打乱其他字符的相对位置)。注意:该题与 1081 https://leetcode-cn.com/problems/smallest-subsequence-of-distinct-characters 相同示例 1:输入:s = "bcabc"输出:"abc"示例 2:输入:s = "cbacdcbc"输出:"acdb"提示:1 <= s.length <= 104s 由小写英文字母组成
import java.util.Stack;class Solution {       public String removeDuplicateLetters(String s) {           Stack
stk = new Stack<>(); // 维护一个计数器记录字符串中字符的数量 // 因为输入为 ASCII 字符,大小 256 够用了 int[] count = new int[256]; for (int i = 0; i < s.length(); i++) { //将字符char转换为int型 count[s.charAt(i)]++; } boolean[] inStack = new boolean[256]; for (char c : s.toCharArray()) { // 每遍历过一个字符,都将对应的计数减一 count[c]--; if (inStack[c]) continue; //表示stack中存在c //stack中不存在c while (!stk.isEmpty() && stk.peek() > c) { // 若之后不存在栈顶元素了,则停止 pop if (count[stk.peek()] == 0) { break; } // 若之后还有,则可以 pop inStack[stk.pop()] = false; } stk.push(c); inStack[c] = true; } StringBuilder sb = new StringBuilder(); while (!stk.empty()) { sb.append(stk.pop()); } return sb.reverse().toString(); }}
上一篇:2 不同字符的最小子序列
下一篇:11 把字符串转换成整数

发表评论

最新留言

哈哈,博客排版真的漂亮呢~
[***.90.31.176]2025年04月06日 23时32分45秒