forked from kyle8998/LeetCode
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathspecial-binary-string.py
42 lines (40 loc) · 1.51 KB
/
special-binary-string.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
# Time: f(n) = k * f(n/k) + n/k * klogk <= O(logn * nlogk) <= O(n^2)
# n is the length of S, k is the max number of special strings in each depth
# Space: O(n)
# Special binary strings are binary strings with the following two properties:
#
# The number of 0's is equal to the number of 1's.
# Every prefix of the binary string has at least as many 1's as 0's.
# Given a special string S, a move consists of choosing two consecutive, non-empty,
# special substrings of S, and swapping them.
# (Two strings are consecutive if the last character of the first string is
# exactly one index before the first character of the second string.)
#
# At the end of any number of moves, what is the lexicographically largest resulting string possible?
#
# Example 1:
# Input: S = "11011000"
# Output: "11100100"
#
# Explanation:
# The strings "10" [occuring at S[1]] and "1100" [at S[3]] are swapped.
# This is the lexicographically largest string possible after some number of swaps.
#
# Note:
# - S has length at most 50.
# - S is guaranteed to be a special binary string as defined above.
class Solution(object):
def makeLargestSpecial(self, S):
"""
:type S: str
:rtype: str
"""
result = []
anchor = count = 0
for i, v in enumerate(S):
count += 1 if v == '1' else -1
if count == 0:
result.append("1{}0".format(self.makeLargestSpecial(S[anchor+1:i])))
anchor = i+1
result.sort(reverse = True)
return "".join(result)