【洛谷 P1106】删数问题 题解(贪心+字符串)

删数问题

题目描述

键盘输入一个高精度的正整数 N N N(不超过 250 250 250 位),去掉其中任意 k k k 个数字后剩下的数字按原左右次序将组成一个新的非负整数。编程对给定的 N N N 和 k k k,寻找一种方案使得剩下的数字组成的新数最小。

输入格式

输入两行正整数。

第一行输入一个高精度的正整数 n n n。

第二行输入一个正整数 k k k,表示需要删除的数字个数。

输出格式

输出一个整数,最后剩下的最小数。

样例 #1

样例输入 #1

复制代码
175438 
4

样例输出 #1

复制代码
13

思路

将 n 作为字符串读入,并在 n 末尾添加一个 0 ,方便比较。

如果当前数字大于等于下一个数字,则删除当前数字。

注意:结果要移除前导零再输出。


AC代码

cpp 复制代码
#include <iostream>
#define AUTHOR "HEX9CF"
using namespace std;

int main()
{
    string n;
    int k;
    cin >> n >> k;
    n += '0';
    while (k)
    {
        for (int i = 0; i < n.length() - 1; i++)
        {
            if (n[i] > n[i + 1])
            {
                string a = n.substr(0, i);
                string b = n.substr(i + 1, n.length() - i - 1);
                // cout << a << " " << b << endl;
                n = a + b;
                k--;
                break;
            }
        }
    }
    int index = n.find_first_not_of('0');
    // cout << index << endl;
    if (!~index)
    {
        index = 0;
    }
    n = n.substr(index, n.length() - index - 1);
    cout << n << endl;
    return 0;
}
相关推荐
信奥卷王5 分钟前
2024年9月GESPC++三级真题解析(含视频)
算法
望未来无悔1 小时前
系统学习算法 专题十八 队列+宽搜
java·算法
Dovis(誓平步青云)1 小时前
《探索C++11:现代语法的性能优化策略(中篇)》
开发语言·c++
xz2024102****1 小时前
最大似然估计:损失函数的底层数学原理
人工智能·算法·机器学习·概率论
一个响当当的名号1 小时前
c++primer 个人学习总结-模板和泛型编程
开发语言·c++·学习
落羽的落羽1 小时前
【C++】C++11的可变参数模板、emplace接口、类的新功能
开发语言·c++·学习
Xの哲學1 小时前
Linux RCU (Read-Copy-Update) 机制深度分析
linux·网络·算法·架构·边缘计算
数模加油站2 小时前
25高教社杯数模国赛【C题国一学长思路+问题分析】第二弹
算法·数学建模·数模国赛·高教社杯全国大学生数学建模竞赛
小跌—2 小时前
Linux:进程信号理解
linux·c++·算法
liulilittle2 小时前
HTTP简易客户端实现
开发语言·网络·c++·网络协议·http·编程语言