C语言 | Leetcode C语言题解之第402题移掉K位数字

题目:

题解:

cpp 复制代码
char* removeKdigits(char* num, int k) {
    int n = strlen(num), top = 0;
    char* stk = malloc(sizeof(char) * (n + 1));
    for (int i = 0; i < n; i++) {
        while (top > 0 && stk[top] > num[i] && k) {
            top--, k--;
        }
        stk[++top] = num[i];
    }
    top -= k;

    char* ans = malloc(sizeof(char) * (n + 1));
    int ansSize = 0;
    bool isLeadingZero = true;
    for (int i = 1; i <= top; i++) {
        if (isLeadingZero && stk[i] == '0') {
            continue;
        }
        isLeadingZero = false;
        ans[ansSize++] = stk[i];
    }
    if (ansSize == 0) {
        ans[0] = '0', ans[1] = 0;
    } else {
        ans[ansSize] = 0;
    }
    return ans;
}
相关推荐
不吃土豆的马铃薯8 分钟前
4.SGI STL 二级空间配置器 allocate 与_S_refill 源码解析
c语言·开发语言·c++·dreamweaver·内存池
水饺编程3 小时前
第5章,[Win32 章节] :几种典型的颜色
c语言·c++·windows·visual studio
Aurorar0rua3 小时前
CS50 x 2024 Notes C -12
c语言·开发语言·学习方法
jimy13 小时前
gnu89和c99中的inline关键字的关系和差异
c语言
x_yeyue6 小时前
2026第十七届蓝桥杯c++B组省赛题解
笔记·算法·蓝桥杯·acm·题解
张二娃同学6 小时前
01_C语言学习路线与开发环境搭建
c语言·开发语言·学习
程序leo源6 小时前
Qt信号与槽深度详解
c语言·开发语言·数据库·c++·qt·c#
老四啊laosi6 小时前
[滑动窗口] 12. 将 x 减到 0 的最小操作数
算法·leetcode·将 x 减到 0 的最小操作数
Simple-Soft7 小时前
指针的高级应用与技巧 - C语言的灵魂
c语言·数据结构·算法
努力努力再努力wz8 小时前
【C++高阶数据结构系列】:时间轮定时器详解:原理分析与代码实现,带你从零手撕时间轮!(附时间轮的实现源码)
c语言·开发语言·数据结构·c++·qt·算法·ui