zoukankan      html  css  js  c++  java
  • leetcode[76]Minimum Window Substring

    Given a string S and a string T, find the minimum window in S which will contain all the characters in T in complexity O(n).

    For example,
    S = "ADOBECODEBANC"
    T = "ABC"

    Minimum window is "BANC".

    Note:
    If there is no such window in S that covers all characters in T, return the emtpy string "".

    If there are multiple such windows, you are guaranteed that there will always be only one unique minimum window in S.

    class Solution {
    public:
    /*
    string minWindow(string S, string T) 
    {
        string res="";
        if(S.empty()||T.empty()||S.size()<T.size())return res;
        int countNeed[256]={0};
        int countHas[256]={0};
        int countT=T.size();
        for (int i=0;i<countT;i++)
        {
            countNeed[T[i]]++;
            countHas[T[i]]++;
        }
        int start=0;
        int minSize=INT_MAX;
        for (int end=0;end<S.size();end++)
        {
            if (countHas[S[end]]>0)
            {
                countNeed[S[end]]--;
                if(countNeed[S[end]]>=0)countT--;
            }
            if (countT==0)
            {
                while(start<S.size())
                {
                    if (countHas[S[start]]>0)
                    {
                        if (countNeed[S[start]]<0)
                        {
                            countNeed[S[start]]++;
                            start++;
                        }
                        else  break;
                    }
                    else  start++;
                }
                if (end-start+1<=minSize)
                {
                    minSize=end-start+1;
                    res=S.substr(start,minSize);
                }
            }
        }
        return res;
    }
    */
    
    string minWindow(string S, string T) 
    {
        string res="";
        if(S.empty()||T.empty()||S.size()<T.size())return res;
        int countT=T.size();
        map<char,int> MapNeed;
        for (int i=0;i<countT;i++)
        {
            MapNeed[T[i]]=0;
        }
        for (int i=0;i<countT;i++)
        {
            MapNeed[T[i]]++;
        }
        int start=0;
        int minSize=INT_MAX;
        for (int end=0;end<S.size();end++)
        {
            if (MapNeed.find(S[end])!=MapNeed.end())
            {
                MapNeed[S[end]]--;
                if (MapNeed[S[end]]>=0)countT--;
            }
            if (countT==0)
            {
                while (start<S.size())
                {
                    if (MapNeed.find(S[start])!=MapNeed.end())
                    {
                        if (MapNeed[S[start]]<0)
                        {
                            MapNeed[S[start]]++;
                            start++;
                        } 
                        else
                        {
                            break;
                        }
                    }
                    else  
                    {
                        start++;
                    }
                }
                if (end-start+1<=minSize)
                {
                    minSize=end-start+1;
                    res=S.substr(start, minSize);
                }
            }
        }
        return res;
    }
    
    };
  • 相关阅读:
    使用Docker容器来源码编译etcd
    PHP开发第一个扩展
    CI框架SESSION重写
    XMLHttpRequest的跨域请求
    PHP哈希表碰撞攻击
    empty、isset、is
    PHP实现4种排序算法
    C实现9种排序算法
    Debian、Ubuntu常用命令大全
    Java中 int和Integer的区别+包装类
  • 原文地址:https://www.cnblogs.com/Vae1990Silence/p/4281461.html
Copyright © 2011-2022 走看看