leetcode 402. 移掉 K 位数字

题目如下

数据范围

复制代码
    本题可以利用贪心来做,显然我们的目标是使得结果串尽量小,  当两个字符串长度相等时靠前的字符越小整个串越小。
例如"1243" k = 1删除4就行,因为剩下的串长度为3最小的自然是 "123" 。
从这里我们可以感觉到其实我们是要让结果串呈现一种递增的态势这样可以保证是所有结果串中最小的。
那么我们可以维持一个递增序列,这个序列就用来保存需要作为答案的下标。显然可以用单调栈来获得这样的序列。
!注意:当题目给出的原本就是递增的只要删除后面k个即可例如: "12345" k = 1 删除5就可以得到最优解。

通过代码

cpp 复制代码
class Solution {
public:
    string removeKdigits(string num, int k) {
        string ans = "";
        int n = num.size();
        if(n <= k)return "0";
        unordered_set<int> set;
        stack<int> s;
        for(int i = 0;i < n;i++){
            while(!s.empty() && num[s.top()] > num[i]){
                if(k == 0)break;
                set.insert(s.top());
                s.pop();
                k--;
            }
            s.push(i);
        }
        for(int i = 0;i < k;i++){
             set.insert(s.top());
                s.pop();
        }
        for(int i = 0;i < n;i++){
            if(!set.contains(i)){
                if(num[i] == '0' && ans.size() == 0)continue;
                ans += num[i] ;
            }
        }
        if(ans.size() == 0)return "0";
        return ans;//时间复杂度On 
    }
};
相关推荐
洛水水4 分钟前
【力扣100题】76.搜索插入位置
数据结构·算法·leetcode
Techblog of HaoWANG8 分钟前
智巡守卫:多模态巡检智能体算法服务端设计与实现——基于Ollama+Qwen3.5的自动化巡检报告生成系统
运维·人工智能·算法·目标检测·自动化·边缘计算
万法若空17 分钟前
C/C++基本类型表示范围
c语言·开发语言·c++
小蒋学算法18 分钟前
算法-灌溉花园的最少龙头数目-贪心
算法
满怀冰雪18 分钟前
第07篇-差分算法-高效处理区间修改问题
数据结构·算法
KaMeidebaby21 分钟前
卡梅德生物技术快报|重组蛋白的表达和纯化:工艺调试全记录:大肠杆菌体系重组蛋白的表达和纯化参数标定(肠激酶轻链案例)
前端·人工智能·算法·数据挖掘·数据分析
凡人叶枫26 分钟前
Effective C++ 条款15:在资源管理类中提供对原始资源的访问
linux·开发语言·c++·stm32·单片机
郝学胜-神的一滴27 分钟前
中级OpenGL教程 009:用环境光告别模型死黑
前端·c++·unity·godot·图形渲染·opengl·unreal
ZPC821036 分钟前
如何将机械臂末端定位精度提升至微米如何进行标定
人工智能·算法·机器人
wabs66638 分钟前
关于动态规划【力扣343.整数拆分的递推公式怎么理解?】
算法·leetcode·动态规划