贪心算法 —— 字典序删除字符

题目描述

给定一个单词,请问在单词删除t个字母之后,能得到的字典序最小的单词是什么?

输入描述

输入的第一行包含一个单词,有大写英文字母组成

第二行包含一个正整数t

其中,单词长度不超过100,t小于单词长度

输出描述

输出一个单词,表示答案

输入输出样例

复制代码
LANQIAO
3

输出

复制代码
AIAO

题解

本题是一道经典的贪心算法的问题。我们要做的就是找到局部最优解,从而获得全局最优解。

首先,什么是字典序最小的排列呢?显然就是在顺序不变的情况下,将小的字符往前排。最终得到的排列一定会是从小到大的阶梯状排序。因此,我们要做的就是每次都从头遍历字符串,将那些升序排列中的"不和谐因素"逐一删除。当然,因为是从头遍历,因此字典序将会是最小。

java 复制代码
import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner scan = new Scanner(System.in);
        String word = scan.next();
        int t = scan.nextInt();

        StringBuilder result = new StringBuilder(word);

        for (int i = 0; i < t; i++) {
            int j = 0;
            while (j < result.length() - 1 && result.charAt(j) <= result.charAt(j + 1)) {
                j++;
            }
            result.delete(j, j + 1);
        }

        System.out.println(result.toString());
        scan.close();
    }
}
相关推荐
Dlrb12114 小时前
C语言-指针三
c语言·算法·指针·const·命令行参数
Tisfy4 小时前
LeetCode 2540.最小公共值:双指针(O(m+n))
算法·leetcode·题解·双指针
IronMurphy4 小时前
【算法四十七】152. 乘积最大子数组
算法
淘矿人5 小时前
Claude辅助DevOps实践
java·大数据·运维·人工智能·算法·bug·devops
Cosolar5 小时前
万字详解:RAG 向量索引算法与向量数据库架构及实战
数据库·人工智能·算法·数据库架构·milvus
小江的记录本5 小时前
【Java基础】泛型:泛型擦除、通配符、上下界限定(附《思维导图》+《面试高频考点清单》)
java·数据结构·后端·mysql·spring·面试·职场和发展
落羽的落羽7 小时前
【算法札记】练习 | Week4
linux·服务器·数据结构·c++·人工智能·算法·动态规划
萑澈7 小时前
算法竞赛入门:C++ STL核心用法与时空复杂度速查手册
数据结构·c++·算法·stl
Godspeed Zhao8 小时前
从零开始学AI16——SVM
算法·机器学习·支持向量机