****402. 移掉K位数字

1. 题目描述

给定一个以字符串表示的非负整数 num,移除这个数中的 k 位数字,使得剩下的数字最小。

注意:

num 的长度小于 10002 且 ≥ k。
num 不会包含任何前导零。
示例 1 :

输入: num = "1432219", k = 3
输出: "1219"
解释: 移除掉三个数字 4, 3, 和 2 形成一个新的最小的数字 1219。
示例 2 :

输入: num = "10200", k = 1
输出: "200"
解释: 移掉首位的 1 剩下的数字为 200. 注意输出不能有任何前导零。
示例 3 :

输入: num = "10", k = 2
输出: "0"
解释: 从原数字移除所有的数字,剩余为空就是0。

 

2. 思路

若num前一个元素比后一个元素大,则删除。直到k==0。

要考虑"0020"这种前缀有0的串,可以直接用int("0020")得到20。

要考虑串的字符有重复,此时比较操作失效,可最后进行字符串截取(考虑字符串“112”,k=1的情况)。

 

3. 实现

 

class Solution:
    def removeKdigits(self, num: str, k: int) -> str:
        if k>len(num)-1:
                return "0"
        i = 0
        while i< len(num)-1 and k>0:
            if int(num[i]) > int(num[i+1]):       
                num = num[:i]+num[i+1:]
                if i>0:
                    i-=1
                k-=1
            else:
                i+=1
        print(num,k)
        num = num[:len(num)-k]   # 针对 int(num[i])==int(num[i+1])的截取
        return str(int(num))    

 

posted @ 2019-08-24 11:05  三年一梦  阅读(141)  评论(0)    收藏  举报