2182. Construct String With Repeat Limit
Description
You are given a string s
and an integer repeatLimit
. Construct a new string repeatLimitedString
using the characters of s
such that no letter appears more than repeatLimit
times in a row. You do not have to use all characters from s
.
Return the lexicographically largest repeatLimitedString
possible.
A string a
is lexicographically larger than a string b
if in the first position where a
and b
differ, string a
has a letter that appears later in the alphabet than the corresponding letter in b
. If the first min(a.length, b.length)
characters do not differ, then the longer string is the lexicographically larger one.
Example 1:
Input: s = "cczazcc", repeatLimit = 3 Output: "zzcccac" Explanation: We use all of the characters from s to construct the repeatLimitedString "zzcccac". The letter 'a' appears at most 1 time in a row. The letter 'c' appears at most 3 times in a row. The letter 'z' appears at most 2 times in a row. Hence, no letter appears more than repeatLimit times in a row and the string is a valid repeatLimitedString. The string is the lexicographically largest repeatLimitedString possible so we return "zzcccac". Note that the string "zzcccca" is lexicographically larger but the letter 'c' appears more than 3 times in a row, so it is not a valid repeatLimitedString.
Example 2:
Input: s = "aababab", repeatLimit = 2 Output: "bbabaa" Explanation: We use only some of the characters from s to construct the repeatLimitedString "bbabaa". The letter 'a' appears at most 2 times in a row. The letter 'b' appears at most 2 times in a row. Hence, no letter appears more than repeatLimit times in a row and the string is a valid repeatLimitedString. The string is the lexicographically largest repeatLimitedString possible so we return "bbabaa". Note that the string "bbabaaa" is lexicographically larger but the letter 'a' appears more than 2 times in a row, so it is not a valid repeatLimitedString.
Constraints:
1 <= repeatLimit <= s.length <= 105
s
consists of lowercase English letters.
Solution
construct-string-with-repeat-limit.py
class Solution:
def repeatLimitedString(self, s: str, repeatLimit: int) -> str:
n = len(s)
words = Counter(s)
heap = []
res = ""
last = (None, 0)
for k, v in words.items():
heapq.heappush(heap, (-ord(k), v))
while len(heap) > 0:
c, v = heapq.heappop(heap)
c = -c
if chr(c) == last[0]:
count = min(repeatLimit, v) - last[1]
if count <= 0:
v = 0
continue
v -= count
res += chr(c) * count
last = (chr(c), count)
else:
count = min(repeatLimit, v)
v -= count
res += chr(c) * count
last = (chr(c), count)
if heap and count == repeatLimit and v != 0:
c2, v2 = heapq.heappop(heap)
c2 = -c2
# print(chr(c), v, chr(c2), v2)
res += chr(c2) * 1
v2 -= 1
if v2 > 0:
heapq.heappush(heap, (-c2, v2))
last = (chr(c2), 1)
if v > 0:
heapq.heappush(heap, (-c, v))
return res