【洛谷 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;
}
相关推荐
忡黑梨9 小时前
eNSP_DHCP配置
c语言·网络·c++·python·算法·网络安全·智能路由器
陈壮实的搬砖日记9 小时前
白话生成式推荐二:MiniOneRec之RQ-VAE
算法
陈壮实的搬砖日记9 小时前
白话生成式推荐二:MiniOneRec之SFT
算法
求学的小高9 小时前
数据结构Day10(ASL、二分查找、分块查找)
数据结构·笔记·考研
我能坚持多久9 小时前
C++的Vector学习:从功能探索到底层实现
开发语言·c++·学习
她说彩礼65万9 小时前
C语言 动态内存管理
c语言·开发语言·算法
凤凰院凶涛QAQ9 小时前
《C++转java快速入手系列》类与对象篇
java·开发语言·c++
Irene19919 小时前
数据排序为什么默认升序
算法·排序
张健11564096489 小时前
std::ranges、std::views和懒加载
开发语言·c++
瞎折腾啥啊9 小时前
现代 CMake 目标系统
c++·cmake·cmakelists