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

题目描述

给定一个单词,请问在单词删除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();
    }
}
相关推荐
Yingye Zhu(HPXXZYY)2 小时前
ICPC 2023 Nanjing R L 题 Elevator
算法
苏小瀚4 小时前
[数据结构] ArrayList(顺序表)与LinkedList(链表)
数据结构
程序员Xu5 小时前
【LeetCode热题100道笔记】二叉树的右视图
笔记·算法·leetcode
笑脸惹桃花5 小时前
50系显卡训练深度学习YOLO等算法报错的解决方法
深度学习·算法·yolo·torch·cuda
阿维的博客日记6 小时前
LeetCode 48 - 旋转图像算法详解(全网最优雅的Java算法
算法·leetcode
GEO_YScsn6 小时前
Rust 的生命周期与借用检查:安全性深度保障的基石
网络·算法
程序员Xu6 小时前
【LeetCode热题100道笔记】二叉搜索树中第 K 小的元素
笔记·算法·leetcode
THMAIL7 小时前
机器学习从入门到精通 - 数据预处理实战秘籍:清洗、转换与特征工程入门
人工智能·python·算法·机器学习·数据挖掘·逻辑回归
Kevinhbr7 小时前
CSP-J/S IS COMING
数据结构·c++·算法
Armyyyyy丶8 小时前
Redis底层实现原理之五大基础结构
数据结构·redis·缓存