• 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);
        }
    };
  • 相关阅读:
    转:配置nodemanager启动weblogic服务器
    SUSE Linux下新建Weblogic 10.3非admin服务
    转weblogic 10.3新建域
    mysql 导出慢
    sql 查询效率
    js isnull 赋值方法
    linux 启动weblogic的某服务报错
    linux下oracle 10g的sqlplus无法使用
    union all 取代 select中的case when 提高查询效率
    php版判断是否为ajax请求的小demo
  • 原文地址:https://www.cnblogs.com/pk28/p/7300929.html
Copyright © 2020-2023  润新知