在这个问题中,我们将使用数组的字母数字字符查找所有 Lyndon 单词。
在开始之前,让我们先了解一下 Lyndon 一词的定义。
所有单词都是 Lyndon 单词,严格按照字典顺序小于其所有循环。
以下是 Lyndon 单词的示例。
ab - “ab”严格按照字典顺序小于其所有排列“ba”。
89 - ‘89’的旋转是‘98’,严格按字典顺序大于‘89’。
abc - ‘abc’的旋转是‘bca’和‘cab’,它们严格大于‘abc’。
以下是非 Lyndon 单词的示例。
aaa - aaa 是非林登词,因为“aaa”的所有旋转都是相同的。
bca - ‘bca’是非林登词,因为‘abc’它的旋转比它小,
问题陈述- 我们给出了一个长度为 K 的字符数组,其中包含字母数字字符。此外,我们还给出了包含正整数的 n。任务是我们需要使用数组中给出的字母数字字符找到长度为 n 的所有 Lyndon 单词。
示例
输入
chars = ['1', '3', '2'], n = 3
输出
112, 113, 122, 123, 132, 133, 223, 233
解释- 它使用数组字符生成了长度为 3 的所有 Lydon 字。
输入
n = 2, chars = ['1', '0']
输出
01
解释-“01”是我们可以使用 0 和 1 组成的唯一 Lyndon 词。
输入
n = 2, chars = ['c', 'a', 'd']
输出
ac, ad, cd
解释- 它使用 a、c 和 d 字符生成长度为 2 的 Lyndon 单词。
方法 1
我们有一种特殊的算法来生成林登词,称为杜瓦尔算法。
算法
第 1 步- 定义代表 Lyndon 单词长度的“n”值和包含创建 Lyndon 单词时要使用的字符的 chars 数组。
第 2 步- 对列表进行排序。
步骤 3 − 用−1 初始化“索引”列表。
第 4 步- 进行迭代,直到索引列表不为空。
第 5 步- 将“索引”列表的最后一个元素增加 1。
第 6 步− 如果 list_size 等于 n,则打印列表值。
第 7 步- 将索引附加到列表,使其长度等于 n。
第 8 步- 如果列表的最后一个元素等于数组的最后一个索引,则将其从列表中删除。
示例
让我们通过示例输入来了解示例。
排序后的列表将为 ['a', 'c', 'd']。
索引列表将在第一次迭代中从 [−1] 更新到 [0]。之后索引的长度就等于2,变成[0, 0]。
在第二次迭代中,列表将更新为 [0, 1],我们找到了第一个 Lyndon 单词“ac”。
在第三次迭代中列表将变为 [0, 2],第二个 Lyndon 单词是“ad”。另外,从列表中删除最后一个元素,因为它等于 array_len -1。
在第四次迭代中,列表将变为 [1]。之后将更新 [1, 1]。
在下一次迭代中列表将变为 [1, 2],并且我们找到了第三个 Lyndon wor,''cd'。
# Input n = 2 chars = ['c', 'a', 'd'] # sort the list initial_size = len(chars) chars.sort() # Initializing the list indexes = [-1] print("The Lyndon words of length {} is".format(n)) # Making iterations while indexes: # Add 1 to the last element of the list indexes[-1] += 1 list_size = len(indexes) # If the list contains n characters, it means we found a Lyndon word if list_size == n: print(''.join(chars[p] for p in indexes)) # Make the list size equal to n by adding characters while len(indexes) < n: indexes.append(indexes[-list_size]) while indexes and indexes[-1] == initial_size - 1: indexes.pop()
输出
The Lyndon words of length 2 is ac ad cd
时间复杂度− O(nlogn),因为我们需要首先对“字符”列表进行排序。
空间复杂度− O(n),因为我们在列表中存储 n 个索引。
Duval 算法是生成长度为 n 的 Lyndon 词的最有效方法。但是,我们已经自定义了仅使用数组字符的方法。
以上是生成长度为n的Lyndon单词的Python程序的详细内容。更多信息请关注PHP中文网其他相关文章!

C 和XML的未来发展趋势分别为:1)C 将通过C 20和C 23标准引入模块、概念和协程等新特性,提升编程效率和安全性;2)XML将继续在数据交换和配置文件中占据重要地位,但会面临JSON和YAML的挑战,并朝着更简洁和易解析的方向发展,如XMLSchema1.1和XPath3.1的改进。

现代C 设计模式利用C 11及以后的新特性实现,帮助构建更灵活、高效的软件。1)使用lambda表达式和std::function简化观察者模式。2)通过移动语义和完美转发优化性能。3)智能指针确保类型安全和资源管理。

C 多线程和并发编程的核心概念包括线程的创建与管理、同步与互斥、条件变量、线程池、异步编程、常见错误与调试技巧以及性能优化与最佳实践。1)创建线程使用std::thread类,示例展示了如何创建并等待线程完成。2)同步与互斥使用std::mutex和std::lock_guard保护共享资源,避免数据竞争。3)条件变量通过std::condition_variable实现线程间的通信和同步。4)线程池示例展示了如何使用ThreadPool类并行处理任务,提高效率。5)异步编程使用std::as

C 的内存管理、指针和模板是核心特性。1.内存管理通过new和delete手动分配和释放内存,需注意堆和栈的区别。2.指针允许直接操作内存地址,使用需谨慎,智能指针可简化管理。3.模板实现泛型编程,提高代码重用性和灵活性,需理解类型推导和特化。

C 适合系统编程和硬件交互,因为它提供了接近硬件的控制能力和面向对象编程的强大特性。1)C 通过指针、内存管理和位操作等低级特性,实现高效的系统级操作。2)硬件交互通过设备驱动程序实现,C 可以编写这些驱动程序,处理与硬件设备的通信。

C 适合构建高性能游戏和仿真系统,因为它提供接近硬件的控制和高效性能。1)内存管理:手动控制减少碎片,提高性能。2)编译时优化:内联函数和循环展开提升运行速度。3)低级操作:直接访问硬件,优化图形和物理计算。

文件操作难题的真相:文件打开失败:权限不足、路径错误、文件被占用。数据写入失败:缓冲区已满、文件不可写、磁盘空间不足。其他常见问题:文件遍历缓慢、文本文件编码不正确、二进制文件读取错误。

深入解析C语言文件操作难题前言文件操作是C语言编程中一项重要的功能。然而,它也可能是一个有挑战性的领域,尤其是在处理复杂文件结构时。本文将深入解析C语言文件操作的常见难题,并提供实战案例来阐明解决方法。打开和关闭文件打开文件时,有两种主要的模式:r(只读)和w(写只)。要打开文件,可以使用fopen()函数:FILE*fp=fopen("file.txt","r");打开文件后,必须在使用完后将其关闭,以释放资源:fclose(fp);读取和写入数据可以使


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

mPDF
mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

SublimeText3 Linux新版
SublimeText3 Linux最新版

螳螂BT
Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

SublimeText3汉化版
中文版,非常好用

安全考试浏览器
Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。