404_boy的解法python3实现.

class Solution:
    def solve(self, str):
        li = list(str)
        oli = []
        i = 0
        for i in range(0, len(li)):
            if not oli:
                oli.append(li[i])
                continue 
            if li[i] == oli[-1]:
                if li[i] == '0':
                    oli[-1] = '1'
                    if len(oli) > 1 and oli[-2] == '1':
                        del oli[-1]
                        del oli[-1]
                else :
                    del oli[-1]
            else:
                oli.append(li[i])
        ans = "".join(oli)
        return ans

我自己写的tle了,404_boy方法时间较短。
主要思想就是空间换时间,你可以把第一次数字转换的结果放到下一次循环去做,但会超时。
规则很巧,转换最多连续两次。
比如oli【……010】
li【……0……】
那么
oli【……0】结束
又如oli【……101】
li【……1……】
那么
oli【……1】结束
最后结果必然是形如101010……或者010101……的稳定态