算法训练-移除K位数字

移除K位数字

1.题目描述

给你一个以字符串表示的非负整数 num 和一个整数 k ,移除这个数中的 k 位数字,使得剩下的数字最小。请你以字符串形式返回这个最小的数字。

示例 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 。

提示:

1 <= k <= num.length <= 105
num 仅由若干位数字(0 - 9)组成
除了 0 本身之外,num 不含任何前导零

2.题目来源

力扣官网

3.题解(JavaScript)

我们要求得移除k位数的最小数字,可以使用单调栈来解答

假设有两个长度相等的数 a=12345678 b=15345678

判断这两个数的大小就是看它们从高位至低位第一个不同数字的大小

例如5>2,故b>a

我们解答这个题目,需要从左至右遍历字符串,保证栈中的元素是单调递增的

如果当前遍历的数字大于或者等于栈顶数字 入栈

如果当前遍历的数字小于栈顶数字 将栈顶数字出栈

var removeKdigits = function(num, k) {
    //如果k大于或者等于字符串的长度,说明字符串可以全部移除,返回'0'
    if(num.length <= k)
    return '0'
    const stk = []
    let ans = ''
    //遍历num
    for(const ch of num){
        //如果遍历的数字小于栈顶元素,栈顶元素出栈,k-1
        while(k&&ch<stk[stk.length-1]&&stk.length){
            stk.pop()
            k--
        }
        stk.push(ch)
    }
    //如果遍历完之后k仍大于0,我们从栈中移除相应数量的数字
    while(k--){
        stk.pop()
    }
    let flag = 0
    //如果有前置0,则不输出前置0
    for(let i=0;i<stk.length;i++){
        if(stk[i]!=0){
            flag=1
        }
        if(flag===1){
            ans+=stk[i]
        }

    }
    return ans===''?'0':ans
};
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值