【Leetcode】2663. 字典序最小的美丽字符串

2024-06-22 10:36

本文主要是介绍【Leetcode】2663. 字典序最小的美丽字符串,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目

题目链接🔗
如果一个字符串满足以下条件,则称其为 美丽字符串

  • 它由英语小写字母表的前 k 个字母组成。
  • 它不包含任何长度为 2 或更长的回文子字符串。

给你一个长度为 n 的美丽字符串 s 和一个正整数 k 。
请你找出并返回一个长度为 n 的美丽字符串,该字符串还满足:在字典序大于 s 的所有美丽字符串中字典序最小。如果不存在这样的字符串,则返回一个空字符串。
对于长度相同的两个字符串 a 和 b ,如果字符串 a 在与字符串 b 不同的第一个位置上的字符字典序更大,则字符串 a 的字典序大于字符串 b 。

  • 例如,“abcd” 的字典序比 “abcc” 更大,因为在不同的第一个位置(第四个字符)上 d 的字典序大于 c 。

示例 1:

输入:s = “abcz”, k = 26
输出:“abda”
解释:字符串 “abda” 既是美丽字符串,又满足字典序大于 “abcz” 。
可以证明不存在字符串同时满足字典序大于 “abcz”、美丽字符串、字典序小于 “abda” 这三个条件。

示例 2:

输入:s = “dc”, k = 4
输出:“”
解释:可以证明,不存在既是美丽字符串,又字典序大于 “dc” 的字符串。

提示:

  • 1 ≤ n = s . l e n g t h ≤ 1 0 5 1 \leq n = s.length \leq 10^5 1n=s.length105
  • 4 < = k < = 26 4 <= k <= 26 4<=k<=26
  • s 是一个美丽字符串 s 是一个美丽字符串 s是一个美丽字符串

思路

首先,我们分析一下美丽字符串的条件:美丽字符串由前 k 个小写字母组成,并且不包含任何长度为 2 或更长的回文子字符串。为了满足这个条件,只需要确保每个字符都不与其前两个字符相同。
接下来,我们需要找到一个字典序大于给定字符串 s 的美丽字符串,并且在所有可能的字符串中字典序最小。为了实现这一点,可以采用贪心算法,从字符串末尾开始逐个字符递增,直到找到满足条件的字符位置。

具体步骤

  1. 寻找可以增大的字符位置:
    • 从字符串末尾开始,逐个字符向前尝试将字符增大。
    • 对于每个字符位置,尝试将其递增一个字符,同时确保新字符不与其前两个字符相同。
  2. 字符递增并检测美丽字符串条件:
    • 找到一个可以增大的字符位置后,将其递增,同时保证新字符不引入长度为 2 或 3 的回文子字符串。
    • 更新该字符后,需要将其后面的字符重置为最小可能值,以确保生成的字符串在字典序上最小。
  3. 处理未找到可增大字符位置的情况:
    • 如果从头到尾都没有找到可以增大的字符位置,则返回空字符串,表示不存在符合条件的字符串。

代码

class Solution {
public:string smallestBeautifulString(string s, int k) {int n = s.size();int index = n - 1;// 步骤 1:寻找可以增大的字符位置while (index >= 0) {int t = s[index] + 1;// 跳过会导致回文子串的字符while (t < 'a' + k && (index > 0 && t == s[index - 1] || index > 1 && t == s[index - 2])) {++t;}if (t < 'a' + k) {s[index] = t;break;}--index;}// 如果没有找到可增大的字符位置,返回空字符串if (index < 0) return "";// 步骤 2:调整剩余的字符为最小的合法字符for (int i = index + 1; i < n; ++i) {s[i] = 'a';// 跳过会导致回文子串的字符while (s[i] == s[i - 1] || (i > 1 && s[i] == s[i - 2])) {++s[i];}}return s;}
};

复杂度分析

时间复杂度

  • 时间复杂度:O(n),因为我们最多需要遍历字符串两次。

空间复杂度

  • 空间复杂度:O(1),只使用了常数级别的额外空间。

结果

在这里插入图片描述

总结

通过上述方法,我们能有效地找到满足条件的下一个美丽字符串。这种方法不仅保证了生成字符串的字典序大于给定字符串,还确保了字典序最小。该解决方案结合了贪心算法和条件检查,使其在处理大规模输入时依然高效可靠。

这篇关于【Leetcode】2663. 字典序最小的美丽字符串的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1084050

相关文章

Java 字符数组转字符串的常用方法

《Java字符数组转字符串的常用方法》文章总结了在Java中将字符数组转换为字符串的几种常用方法,包括使用String构造函数、String.valueOf()方法、StringBuilder以及A... 目录1. 使用String构造函数1.1 基本转换方法1.2 注意事项2. 使用String.valu

python修改字符串值的三种方法

《python修改字符串值的三种方法》本文主要介绍了python修改字符串值的三种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录第一种方法:第二种方法:第三种方法:在python中,字符串对象是不可变类型,所以我们没办法直接

JAVA中整型数组、字符串数组、整型数和字符串 的创建与转换的方法

《JAVA中整型数组、字符串数组、整型数和字符串的创建与转换的方法》本文介绍了Java中字符串、字符数组和整型数组的创建方法,以及它们之间的转换方法,还详细讲解了字符串中的一些常用方法,如index... 目录一、字符串、字符数组和整型数组的创建1、字符串的创建方法1.1 通过引用字符数组来创建字符串1.2

python 字典d[k]中key不存在的解决方案

《python字典d[k]中key不存在的解决方案》本文主要介绍了在Python中处理字典键不存在时获取默认值的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,... 目录defaultdict:处理找不到的键的一个选择特殊方法__missing__有时候为了方便起见,

C#中字符串分割的多种方式

《C#中字符串分割的多种方式》在C#编程语言中,字符串处理是日常开发中不可或缺的一部分,字符串分割是处理文本数据时常用的操作,它允许我们将一个长字符串分解成多个子字符串,本文给大家介绍了C#中字符串分... 目录1. 使用 string.Split2. 使用正则表达式 (Regex.Split)3. 使用

Java中JSON字符串反序列化(动态泛型)

《Java中JSON字符串反序列化(动态泛型)》文章讨论了在定时任务中使用反射调用目标对象时处理动态参数的问题,通过将方法参数存储为JSON字符串并进行反序列化,可以实现动态调用,然而,这种方式容易导... 需求:定时任务扫描,反射调用目标对象,但是,方法的传参不是固定的。方案一:将方法参数存成jsON字

哈希leetcode-1

目录 1前言 2.例题  2.1两数之和 2.2判断是否互为字符重排 2.3存在重复元素1 2.4存在重复元素2 2.5字母异位词分组 1前言 哈希表主要是适合于快速查找某个元素(O(1)) 当我们要频繁的查找某个元素,第一哈希表O(1),第二,二分O(log n) 一般可以分为语言自带的容器哈希和用数组模拟的简易哈希。 最简单的比如数组模拟字符存储,只要开26个c

poj 1258 Agri-Net(最小生成树模板代码)

感觉用这题来当模板更适合。 题意就是给你邻接矩阵求最小生成树啦。~ prim代码:效率很高。172k...0ms。 #include<stdio.h>#include<algorithm>using namespace std;const int MaxN = 101;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int n

poj 1287 Networking(prim or kruscal最小生成树)

题意给你点与点间距离,求最小生成树。 注意点是,两点之间可能有不同的路,输入的时候选择最小的,和之前有道最短路WA的题目类似。 prim代码: #include<stdio.h>const int MaxN = 51;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int P;int prim(){bool vis[MaxN];

poj 2349 Arctic Network uva 10369(prim or kruscal最小生成树)

题目很麻烦,因为不熟悉最小生成树的算法调试了好久。 感觉网上的题目解释都没说得很清楚,不适合新手。自己写一个。 题意:给你点的坐标,然后两点间可以有两种方式来通信:第一种是卫星通信,第二种是无线电通信。 卫星通信:任何两个有卫星频道的点间都可以直接建立连接,与点间的距离无关; 无线电通信:两个点之间的距离不能超过D,无线电收发器的功率越大,D越大,越昂贵。 计算无线电收发器D