MT2097 小码哥爱数字

贪心思路:

1.错误思路:每次删去最大的数字。

n=1528,k=1,如果删去8,则为152;如果删去5,则为128<152。

2.正确思路:从左到右遍历字符串,如果前面的数>后面的数,则删去前面的数。

如果遍历完后没有这样的数,则删去最后一位。

3.注意:输出时也要考虑前导0;例如n=1008,k=1,应该删除1,结果为008,应该输出8。

代码:

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
string s;
int k, p;

int main()
{
    cin >> s;
    cin >> k;
    int len = s.length();
    while (k--)
    {
        for (int i = 0; i < len; i++)
        {
            if (s[i] > s[i + 1])
            {
                for (int j = i; j < len; j++)
                {
                    s[j] = s[j + 1]; // 删除第i位,后面的元素前移
                }
                len--;
                break;
            }
        }
    }
    while (p < len - 1 && s[p] == '0')
        p++; // 删除前导0
    for (int i = p; i < len; i++)
    {
        cout << s[i];
    }
    return 0;
}
相关推荐
We་ct1 小时前
LeetCode 289. 生命游戏:题解+优化,从基础到原地最优
前端·算法·leetcode·矩阵·typescript
自己的九又四分之三站台1 小时前
9:MemNet记忆层使用,实现大模型对话上下文记忆
人工智能·算法·机器学习
sayang_shao1 小时前
C++ ONNX Runtime 与 Python Ultralytics 库实现 YOLOv8 模型检测的区别
c++·python·yolo
LXS_3572 小时前
STL - 函数对象
开发语言·c++·算法
aini_lovee2 小时前
基于粒子群算法(PSO)优化BP神经网络权值与阈值的实现
神经网络·算法
专注于ai算法的踩坑小达人2 小时前
C++变量全面总结
c++·qt
老鼠只爱大米2 小时前
LeetCode经典算法面试题 #230:二叉搜索树中第K小的元素(递归法、迭代法、Morris等多种实现方案详细解析)
算法·leetcode·二叉搜索树·二叉树遍历·第k小的元素·morris遍历
星期五不见面2 小时前
嵌入式学习!(一)C++学习-leetcode(21)-26/1/29
学习·算法·leetcode
阿猿收手吧!2 小时前
【C++】atmoic原子操作与并发安全全解析
开发语言·c++·安全
2501_941322032 小时前
通信设备零部件识别与检测基于改进YOLOv8-HAFB-2算法实现
算法·yolo