题解 | #移掉 K 位数字#

移掉 K 位数字

http://www.nowcoder.com/practice/0fe685c8272d40f1b9785fedd2499c1c

单调栈的简单运用。


class Solution {
public:
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * 
     * @param num string字符串 
     * @param k int整型 
     * @return string字符串
     */
    string removeKnums(string num, int k) {
        // write code here
        stack<int> Stack;
        for(int i = 0;i < num.size();){
            if(Stack.empty()){
                Stack.push(num[i] - '0');
                ++i;
            }
            else if(Stack.top() <= num[i] - '0' && Stack.size() != num.size() - k){
                Stack.push(num[i] - '0');
                ++i;
            }
            else if(Stack.size() + num.size() - i != num.size() - k)
                    Stack.pop();
            else{
                 Stack.push(num[i] - '0');
                 ++i;
            }
        }
        string ans;
        while(!Stack.empty()){
            ans = to_string(Stack.top()) + ans;
            Stack.pop();
        }
        if(ans[0] == '0' && ans.size() != 1)
            ans = ans.substr(ans.find_first_not_of('0'));
        return ans.c_str();
    }
};
全部评论

相关推荐

11-17 11:15
门头沟学院 Java
金山办公终于发offer了,但薪资和平台都不如已有的offer打算拒了,A不了薪资,不满意直接拒了,留给需要的人嘿嘿嘿时间线:10.14线下一面&nbsp;,10.23线上二面,下午发测评,11月1日HR面,11月14日电话谈薪,11月17日直接发offer
star__plat...:好兄弟干的好啊,解气。金山第一次笔难度高的离谱,第二次简单的离谱全A了,用人部门筛选中估计最后还是要挂我,就这今早智联招聘还给我发信息让我投
offer帮选
点赞 评论 收藏
分享
10-29 15:51
嘉应学院 Java
后端转测开第一人:你把简历的学历改成北京交通大学 去海投1000份发现基本还是没面试
点赞 评论 收藏
分享
八极星:有什么不能问的,(/_\),这又不是多珍贵的机会,你有什么可失去的
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务