Output: Return 4, and the first 4 characters of the input array should be: ["a","b","1","2"].
Explanation: Since the character "a" does not repeat, it is not compressed. "bbbbbbbbbbbb" is replaced by "b12". Notice each digit has it's own entry in the array.
Note:
All characters have an ASCII value in [35, 126].
1 <= len(chars) <= 1000.
分析
双指针问题。
解决方案1(Python)
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19
class Solution: def compress(self, chars: List[str]) -> int: charsLen = len(chars) left = 0 now = 0 while left < charsLen: right = left while right < charsLen and chars[right] == chars[left]: right += 1 chars[now] = chars[left] now += 1 if right-left > 1: for ch in str(right-left): chars[now] = ch now += 1 left = right return now