2021秋招_TME_算法岗_笔试_部分题目

第二题

字典序,越左的权重越大

所以应该找最左边的一个0序列,将其反转为1即可

后面的不需要动

#
# 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
#
# 
# @param num string字符串 
# @return string字符串
#
class Solution:
    def maxLexicographical(self , num ):
        rel = ''
        # 拼接字符串,用于返回结果
        label = 1
        for i in range(len(num)):
        # 遍历原始字符串的每一位
            if (num[i] == '1') and label :
            # 未遇到0,直接拼接
                rel += num[i]
            elif (num[i] == '0'):
                rel += '1'
                label = 0
            # 遇到0,拼接为1
            elif (num[i] == '1') and not(label):
            # 遇到0之后,再遇到1,拼接剩下的部分
                rel += num[i:len(num)]
                break
            # 拼接完毕后跳出循环
        return rel

method = Solution()
print(method.maxLexicographical('1001'))
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值