zoukankan      html  css  js  c++  java
  • Java实现 LeetCode 316 去除重复字母

    316. 去除重复字母

    给定一个仅包含小写字母的字符串,去除字符串中重复的字母,使得每个字母只出现一次。需保证返回结果的字典序最小(要求不能打乱其他字符的相对位置)。

    示例 1:

    输入: “bcabc”
    输出: “abc”
    示例 2:

    输入: “cbacdcbc”
    输出: “acdb”

    PS:
    我把每一个数出现的次数都拿出来,我当前字符比我栈顶的小,并且我栈顶的字符还有多的在后面,我就可以把他替换了,记录一下是否使用

    class Solution {
       public String removeDuplicateLetters(String s) {
            int[] charsCount = new int[26];//计算26字母数量
            boolean[] visited = new boolean[26];//标记字母是否已经入栈
            int len = s.length();
            char[] sChars = s.toCharArray();
            for (char c : sChars) {
                charsCount[c - 'a']++;
            }
            Stack<Character> stack = new Stack<>();
            int index = 0;//最终字符的长度
            for (int count : charsCount) {
                if (count > 0) index++;
            }
            char[] res = new char[index];
            for (int i = 0; i < len; i++) {
                char c = s.charAt(i);
                //有小字符的且满足其前面的字符在小字符后还有同样字符的,则出栈
                while (!stack.isEmpty() && c < stack.peek() && charsCount[stack.peek() - 'a'] > 1 && !visited[c - 'a']) {
                    Character pop = stack.pop();
                    visited[pop - 'a'] = false;
                    charsCount[pop - 'a']--;
                }
                if (visited[c - 'a']) {
                    charsCount[c - 'a']--;//重复的字符根据游标往后移动,数量减一
                    continue;
                }
                stack.push(c);
                visited[c - 'a'] = true;
            }
    
            while (!stack.isEmpty()) {
                res[--index] = stack.pop();
            }
            return String.valueOf(res);
        }
    }
    
  • 相关阅读:
    迁移MSSQL实例的所有login(包含密码)
    某公司的存储过程模板(摘抄自高大神的博客)
    检测和终结死锁
    70-461学习笔记,关于几个日期函数
    Oracle-12541:TNS:无监听程序 .
    C#- 实用的Log4Net日志记录例子
    EASYUI- EASYUI左移右移 GRID中值
    MYSQL- 分页存储过程
    MSSQLSERVER数据库- 一条代码搞定单表备份表结构和表数据
    Delphi- 操作EXCEL
  • 原文地址:https://www.cnblogs.com/a1439775520/p/13075882.html
Copyright © 2011-2022 走看看