牛牛的01游戏

牛牛的01游戏

http://www.nowcoder.com/questionTerminal/6e0b8db437804169800a10f097d35b6a

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……的稳定态

全部评论

相关推荐

02-11 14:29
已编辑
字节跳动_QA
Edgestr:这种的写代码最狠了
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务