LeetCode - 贪心 - 402. 移掉K位数字

给定一个非负整数 num 和整数 k,你需要移除 num 中的 k 位数字,使剩下的数字最小。通过贪心策略,从左到右遍历数字,如果当前数字小于栈顶数字,则弹出栈顶数字,否则将当前数字压入栈。最后处理特殊情况,移除多余数字和前导零,得到最小数字。
摘要由CSDN通过智能技术生成

402. 移掉K位数字

给定一个以字符串表示的非负整数 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。

简单介绍:
难度:中等
使用语言:JAVA。
这道题来自leetcode题库的贪心算法标签。

解题思路:
首先看题、分析题意:

  1. 暴力枚举肯定会超时,所以要缩短时间
  2. 要求数字最小,即高位越小则整体数值就越小
  3. 从左到右遍历删除,选择最小的组合
  4. 利用栈来实现这种思想

既然,我们已经分析出来题目的关键任务了,下面我们就可以开始思考实现了。
我们采用算法与数据结构的思路来剖析一下这题

数据结构:
要实现对数据的操作,我们要先明确存储数据的数据结构。
LinkedList < Character > Stack - 利用栈来存储

算法

  • 对于每个数字,如果该数字小于栈顶部,即该数字的左邻居,则弹出堆栈,即删除左邻居。否则,我们把数字推到栈上。
  • 我们重复上述步骤,直到任何条件不再适用,例如堆栈为空(不再保留数字)。或者我们已经删除了 k 位数字
    在这里插入图片描述
    特殊情况
  • 当我们离开主循环时,我们删除了 m 个数字,这比要求的要少&#
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值