Given two strings s and t of lengths m and n respectively, return the minimum window substring ofssuch that every character int(including duplicates) is included in the window. If there is no such substring__, return the empty string"".
The testcases will be generated such that the answer is unique.
A substring is a contiguous sequence of characters within the string.
Example 1:
Input: s = “ADOBECODEBANC”, t = “ABC” Output: “BANC” Explanation: The minimum window substring “BANC” includes ‘A’, ‘B’, and ‘C’ from string t.
Example 2:
Input: s = “a”, t = “a” Output: “a” Explanation: The entire string s is the minimum window.
Example 3:
Input: s = “a”, t = “aa” Output: “” Explanation: Both ‘a’s from t must be included in the window. Since the largest window of s only has one ‘a’, return empty string.
Constraints:
m == s.lengthn == t.length 1 <= m, n <= 10<sup>5</sup>s and t consist of uppercase and lowercase English letters.
Follow up: Could you find an algorithm that runs in O(m + n) time?
defminWindow(self, s: str, t: str) -> str: t_char_to_count = collections.Counter(t) left, unique_count, min_len, res = 0, 0, float('inf'), '' for i inrange(len(s)): if s[i] in t_char_to_count: t_char_to_count[s[i]] -= 1 if t_char_to_count[s[i]] == 0: unique_count += 1 while unique_count == len(t_char_to_count): if i - left + 1 < min_len: min_len = i - left + 1 res = s[left:i + 1] if s[left] in t_char_to_count: t_char_to_count[s[left]] += 1 if t_char_to_count[s[left]] == 1: unique_count -= 1 left += 1 return res
A string can be abbreviated by replacing any number of non-adjacent, non-empty substrings with their lengths. The lengths should not have leading zeros.
For example, a string such as "substitution" could be abbreviated as (but not limited to):
"s10n" ("s <u>ubstitutio</u> n")
"sub4u4" ("sub <u>stit</u> u <u>tion</u>") "12" ("<u>substitution</u>")
"su3i1u2on" ("su <u>bst</u> i <u>t</u> u <u>ti</u> on") "substitution" (no substrings replaced)
The following are not valid abbreviations:
"s55n" ("s <u>ubsti</u> <u>tutio</u> n", the replaced substrings are adjacent) "s010n" (has leading zeros)
"s0ubstitution" (replaces an empty substring)
Given a string word and an abbreviation abbr, return whether the string matches the given abbreviation.
A substring is a contiguous non-empty sequence of characters within a string.
Example 1:
Input: word = “internationalization”, abbr = “i12iz4n” Output: true Explanation: The word “internationalization” can be abbreviated as “i12iz4n” (“i nternational iz atio n”).
Example 2:
Input: word = “apple”, abbr = “a2e” Output: false Explanation: The word “apple” cannot be abbreviated as “a2e”.
Constraints:
1 <= word.length <= 20word consists of only lowercase English letters. 1 <= abbr.length <= 10abbr consists of lowercase English letters and digits. * All the integers in abbr will fit in a 32-bit integer.
Convert a Binary Search Tree to a sorted Circular Doubly-Linked List in place.
You can think of the left and right pointers as synonymous to the predecessor and successor pointers in a doubly-linked list. For a circular doubly linked list, the predecessor of the first element is the last element, and the successor of the last element is the first element.
We want to do the transformation in place. After the transformation, the left pointer of the tree node should point to its predecessor, and the right pointer should point to its successor. You should return the pointer to the smallest element of the linked list.
Example 1:
Input: root = [4,2,5,1,3]
Output: [1,2,3,4,5]
Explanation: The figure below shows the transformed BST. The solid line indicates the successor relationship, while the dashed line means the predecessor relationship.
Example 2:
Input: root = [2,1,3] Output: [1,2,3]
Constraints:
The number of nodes in the tree is in the range [0, 2000].
-1000 <= Node.val <= 1000 All the values of the tree are *unique.
题目大意:
将二叉树变成双向链表,left为父节点,right为儿子节点
解题思路:
类似于LeetCode 114 Flatten Binary Tree to Linked List,先假设左右儿子,已经是双向LL,下面就是将root这个节点插入到两个LL之间其将它们首尾相连
You are given two strings order and s. All the words of order are unique and were sorted in some custom order previously.
Permute the characters of s so that they match the order that order was sorted. More specifically, if a character x occurs before a character y in order, then x should occur before y in the permuted string.
Return any permutation ofsthat satisfies this property.
Example 1:
Input: order = “cba”, s = “abcd” Output: “cbad” Explanation: “a”, “b”, “c” appear in order, so the order of “a”, “b”, “c” should be “c”, “b”, and “a”. Since “d” does not appear in order, it can be at any position in the returned string. “dcba”, “cdba”, “cbda” are also valid outputs.
Example 2:
Input: order = “cbafg”, s = “abcd” Output: “cbad”
Constraints:
1 <= order.length <= 261 <= s.length <= 200 order and s consist of lowercase English letters.
All the characters of order are unique.
defcustomSortString(self, order: str, s: str) -> str: char_to_count = collections.Counter(s) res = '' for c in order: if c in char_to_count: res += c * char_to_count[c] char_to_count.pop(c) for c, count in char_to_count.items(): res += c * count return res