****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))

浙公网安备 33010602011771号