zoukankan      html  css  js  c++  java
  • leetcode 316. Remove Duplicate Letters

    Given a string which contains only lowercase letters, remove duplicate letters so that every letter appear once and only once. You must make sure your result is the smallest in lexicographical order among all possible results.

    Example:

    Given "bcabc"
    Return "abc"

    Given "cbacdcbc"
    Return "acdb"

    题目意思:去掉重复的字符,保持元序列的位置,并使得字典序最小

    真的是。。。想了半天也没想到用栈。看了他人的代码,还有用string 直接搞的

    class Solution {
    public:
        string removeDuplicateLetters(string s) {
            int n = s.length();
            vector<int> cnt(26);
            vector<int> vis(26);
            for (int i = 0; i < n; ++i) {
                int x = s[i] - 'a';
                cnt[x]++;
            }
            stack<int> st;
            for (int i = 0; i < n; ++i) {
                int x = s[i] - 'a';
                cnt[x]--;
                if (st.empty()) {
                    st.push(x);
                    vis[x] = 1;
                }
                else {
                    while (!st.empty() && st.top() > x && cnt[st.top()] && !vis[x]) {
                        vis[st.top()] = 0;
                        st.pop();
                    }
                    if (!vis[x]) st.push(x),vis[x] = 1;
                }
            }
            string t = "";
            while (!st.empty()) {
                int y = st.top();
                st.pop();
                t = char(y + 'a') + t;
            }
            return t;
        }
    };
    class Solution {
    public:
        string removeDuplicateLetters(string s) {
            vector<int> dict(256, 0);
            vector<bool> visited(256, false);
            for(auto ch : s)  dict[ch]++;
            string result = "0";
            /** the key idea is to keep a monotically increasing sequence **/
            for(auto c : s) {
                dict[c]--;
                /** to filter the previously visited elements **/
                if(visited[c])  continue;
                while(c < result.back() && dict[result.back()]) {
                    visited[result.back()] = false;
                    result.pop_back();
                }
                result += c;
                visited[c] = true;
            }
            return result.substr(1);
        }
    };
  • 相关阅读:
    制作你的第一个HTML 5游戏
    拒绝臆想,让我们脚踏实地做设计!
    HTML 5或者Silverlight?
    如何替换掉回车键
    杀死团队的武器与修复团队的方法
    Google趋势中显示jQuery是最流行的JavaScript框架
    关于脚本载入器的思考
    简化Web开发的12个HTML5CSS框架
    线框图(demo草图)制作的总结
    江苏南通周边经纬度
  • 原文地址:https://www.cnblogs.com/pk28/p/7300929.html
Copyright © 2011-2022 走看看