-
Notifications
You must be signed in to change notification settings - Fork 0
/
string_compression.py
32 lines (28 loc) · 1 KB
/
string_compression.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
"""
Page 91 - Cracking the Coding Interview
1.6 String Compression: Implement a method to perform basic string compression using the counts
of repeated characters. For example, the string aabcccccaaa would become a2blc5a3. If the
"compressed" string would not become smaller than the original string, your method should return
the original string. You can assume the string has only uppercase and lowercase letters (a - z).
"""
def compressString(string):
prevIndex = 0
newStr = []
count = 1
index = 1
while index <= len(string):
newStr.append(string[prevIndex])
if index < len(string) and string[index] == string[prevIndex]:
count += 1
prevIndex += 1
index += 1
else:
newStr.append(str(count))
count = 1
prevIndex = index
index += 1
return "".join(newStr)
if __name__ == "__main__":
inputStr = "aaaaabbccddeeffgghh"
compressedStr = compressString(inputStr)
print(compressedStr)