第40题——删除数最大(贪心): 给你一个整数 n,使得从 n 中删除 k 个数字之后的数字最大。

复制代码
题目描述

给你一个整数 n,使得从 n 中删除 k 个数字之后的数字最大。

输入
输入一个整数 n (0 <= n <= 10^100),和需要删除数字 k <= 100的个数

输出
输出删除k个数字之后的最大整数
cpp 复制代码
#include<stdio.h>
#include<string.h>
int main(){
    char n[1000];int k,i,t,len;
    while(scanf("%s%d",&n,&k)!=EOF){
    //while(~scanf("%s%d",&n,&k)){
        len=strlen(n);//获取字符串长度
        while(k--){
            for(i=0;i<len-1;i++) {
                if (n[i] < n[i + 1]) {
                    break;
                } //从最高位开始找,找到到高位小于低位的 就跳出
            }
            while(i+1<len){
                n[i]=n[i+1],i++;//通过移位覆盖法删掉应该移除的元素。(之后就相当于要移除最后一个元素)
            }
            len--;//字符串长度减少 (若应该去除最后一个元素 ,直接 长度减少)
        }
        n[len]=0;
        printf("%s\n",n);
    }
    return 0;
}
复制代码
通过贪心的方法:
根据题意, 就是删除k个数字 保持原序列顺序不变的情况 下,使得 剩下的数字组成的最大。
我们一般比较一个数的大小,是怎么比的 ,比如 8999 9000 ,是不是先看最高位,
第一个数最高位为8 第二个数最高位为9,那么后面根本就不用关心。所以一个数大不大 由高位决定。
最高位相同,比次高位,依次类推。因此此题可以按以下步骤解决。
1.从最高位 开始找,找相邻的两个数中,高位的数字小于低位的数字,则应该把 高位的数字删掉,
2.如果是一个原序列是一个递减序列(或者 全为 11111 这种均匀序列),则删除最后一个元素就好了。
相关推荐
算法熔炉几秒前
深度学习面试八股文(2)——训练
人工智能·深度学习·算法
EXtreme358 分钟前
【数据结构】打破线性思维:树形结构与堆在C语言中的完美实现方案
c语言·数据结构·算法··heap·完全二叉树·topk
cici1587410 分钟前
含风电场的十机24时系统机组出力优化算法
人工智能·算法·机器学习
ss27312 分钟前
跳表(SkipList)平衡树的数据结构设计与并发实践
数据结构·skiplist
WolfGang00732115 分钟前
代码随想录算法训练营Day45 | 101.孤岛的总面积、102.沉没孤岛、103.水流问题、104.建造最大岛屿
算法·深度优先
2301_7644413316 分钟前
PMC政策文本量化评估
python·算法·信息可视化
代码游侠21 分钟前
应用——Linux进程编程实例分析
linux·运维·网络·笔记·学习·算法
DuHz23 分钟前
《Around the Corner mmWave Imaging in Practical Environments》论文精读
论文阅读·算法·信息与通信·毫米波雷达
CoderYanger28 分钟前
D.二分查找-基础-2529. 正整数和负整数的最大计数
java·开发语言·数据结构·算法·leetcode·职场和发展
想唱rap29 分钟前
Linux下进程的控制
linux·运维·服务器·c++·算法