A string S containing only the letters "A", "B" and "C" is given. The string can be transformed by removing one occurrence of "AA", "BB" or "CC".
Transformation of the string is the process of removing letters from it, based on the rules described above. As long as at least one rule can be applied, the process should be repeated. If more than one rule can be used, any one of them could be chosen.
Write a function:
def solution(S)
that, given a string S consisting of N characters, returns any string that can result from a sequence of transformations as described above.
For example, given string S = "ACCAABBC" the function may return "AC", because one of the possible sequences of transformations is as follows:
Also, given string S = "ABCBBCBA" the function may return "", because one possible sequence of transformations is:
Finally, for string S = "BABABA" the function must return "BABABA", because no rules can be applied to string S.
Write an efficient algorithm for the following assumptions:
- the length of string S is within the range [0..50,000];
- string S is made only of the following characters: 'A', 'B' and/or 'C'.
Traceback (most recent call last): File "exec.py", line 123, in <module> main() File "exec.py", line 85, in main result = solution( S ) File "/tmp/solution.py", line 9, in solution if s == stack[-1]: IndexError: list index out of range
Traceback (most recent call last): File "exec.py", line 123, in <module> main() File "exec.py", line 85, in main result = solution( S ) File "/tmp/solution.py", line 9, in solution if s == stack[-1]: IndexError: list index out of range
Traceback (most recent call last): File "exec.py", line 123, in <module> main() File "exec.py", line 85, in main result = solution( S ) File "/tmp/solution.py", line 9, in solution if s == stack[-1]: IndexError: list index out of range
Invalid result type, string expected, <class 'NoneType'> found.stdout:
['A', 'C']
Invalid result type, string expected, <class 'NoneType'> found.stdout:
[]
Invalid result type, string expected, <class 'NoneType'> found.stdout:
['B', 'A', 'B', 'A', 'B', 'A']
Invalid result type, string expected, <class 'NoneType'> found.stdout:
AC
Invalid result type, string expected, <class 'NoneType'> found.stdout:
Invalid result type, string expected, <class 'NoneType'> found.stdout:
BABABA
The solution obtained perfect score.