标签:char end start res Substring 76 Window dict my
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).
Example:
Input: S = "ADOBECODEBANC", T = "ABC" Output: "BANC"
Note:
- If there is no such window in S that covers all characters in T, return the empty string
""
. - If there is such window, you are guaranteed that there will always be only one unique minimum window in S.
Time: O(N)
class Solution: def minWindow(self, s: str, t: str) -> str: res = '' my_dict = {} for char in t: freq = my_dict.get(char, 0) my_dict[char] = freq + 1 count, start, end, min_len = len(my_dict), 0, 0, sys.maxsize res_end, res_start = 0, 0 while end != len(s): char = s[end] if char in my_dict: my_dict[char] -= 1 if my_dict[char] == 0: count -= 1 end += 1 while count == 0: start_char = s[start] if start_char in my_dict: my_dict[start_char] += 1 if my_dict[start_char] > 0: count += 1 if min_len > end - start: min_len = end - start res_end = end res_start = start start += 1 return s[res_start: res_end]
标签:char,end,start,res,Substring,76,Window,dict,my 来源: https://www.cnblogs.com/xuanlu/p/11660721.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。