`
isiqi
  • 浏览: 16585676 次
  • 性别: Icon_minigender_1
  • 来自: 济南
社区版块
存档分类
最新评论

字典序全排列生成算法

阅读更多

为了交作业忙了一天,历尽3次优化,对123456789生成无遗漏,无重复的排列数,一共9阶层个情况。

从最naive的版本执行1.263s,提高到1.250s,在提高到0.89s,最后提高到0.047s。先卖个关子,赶紧回去吃饭。

明天整理好代码贴上来。

整理在另外一个博文中,参见:http://blog.csdn.net/pennyliang/archive/2010/11/05/5989555.aspx

分享到:
评论

相关推荐

    全排列生成算法字典序vc++源码

    在VC++环境中,你可以将这段代码保存为`ZiDianXu.cpp`,然后使用编译器进行编译和运行,以得到123序列的字典序全排列结果。 这个算法的时间复杂度为O(n!),因为它需要生成n!个排列。空间复杂度取决于递归深度,最坏...

    利用中介数实现全排列算法

    利用中介数实现全排列算法,采用java实现。

    排列生成算法 之字典序发与邻位互换法

    排列生成算法是计算机科学中处理有限集合的一种方法,主要用于生成所有可能的排列顺序。这里主要讨论两种算法:字典序法和邻位互换法。 字典序法是一种按照特定顺序(通常是最小字典序)生成排列的算法。在字典序中...

    全排列生成算法(字典序、邻位对换、递增进位制数,递减进位制数)

    全排列生成算法是计算机科学中一个经典的问题,主要应用于数据处理、组合优化等领域。本话题主要探讨了四种不同的方法:字典序排列、邻位对换、递增进位制数和递减进位制数,并提供了C++语言的实现。 1. **字典序...

    组合数学全排列生成算法

    本项目提供了C语言实现的四种常见全排列生成算法,分别是字典序法、循环左移、循环右移以及邻位对换方法。 1. **字典序法**: 字典序法是一种按照特定顺序(通常是最小到最大)生成排列的方法。在C语言中,可以...

    四种权威全排列生成算法.pdf

    本文件主要介绍了四种权威的全排列生成算法,分别是字典序(基于中介数)算法、字典序(基于相邻排列特征)算法、递增进位制数法和递减进位制数法。这些算法可以帮助程序员有效地生成一个给定数组的所有可能全排列,...

    全排列的生成算法

    全排列的生成算法 全排列的生成算法是指对于给定的字符集,用有效的方法将所有可能的全排列无重复无遗漏地枚举出来。任何 n 个字符集的排列都可以与 1~n 的 n 个数字的排列一一对应,因此在此就以 n 个数字的排列...

    word版全排列生成算法

    本篇文章将详细介绍几种常见的全排列生成算法,包括字典序法、递增进位数制法、递减进位数制法、邻位交换法、n进位制法以及递归类算法。通过这些方法,可以高效地生成给定字符集的所有可能排列。 #### 二、字典序法...

    四种权威全排列生成算法.docx

    本篇文章将详细介绍四种权威全排列生成算法,包括基于中介数、相邻排列特征、递增进位制数法和递减进位制数法的方法。 1. 基于中介数的全排列算法: 这种方法通常用于生成字典序排列。在`Zidian1_1`和`Zidian1_2`...

    全排列的算法 翻转法 换位法 字典序法

    本篇将详细介绍三种解决全排列问题的算法:翻转法、换位法和字典序法。 1. **翻转法**: 翻转法是一种基于回溯思想的全排列算法。基本思路是从第一个元素开始,每次选择一个未使用的元素放置在当前排列的末尾,然后...

    字典排序求全排列的算法

    总之,字典排序求全排列的算法通过Java实现,结合了回溯法和深度优先搜索策略,遵循字典序规则生成所有可能的排列。理解并掌握这种算法有助于提升编程能力和解决复杂问题的能力。在实际应用中,这种算法可用于生成...

    基于C实现的按照字典序生成排列的算法(字典序)

    以下是一个基于深度优先搜索(DFS)的字典序排列生成算法的基本思路: 1. 为每个元素创建一个标记数组,用于记录当前元素是否已被使用过。 2. 定义一个递归函数,该函数接受当前排列的数组和剩余未使用元素的计数。...

    全排列算法解析(完整版)

    以上内容涵盖了全排列算法的多个重要方面,包括基本定义、时间复杂度分析、算法设计、递归方法、字典序排列、STL函数使用、中介数概念、进位制方法、邻位对换法以及组合数生成等。这些知识点对于理解全排列算法的...

    全排列算法解析(完整版)

    这些方法都是全排列生成的具体算法,它们基于不同的逻辑和优化策略。例如: - **递进出位制数法**:通过模拟递增的进位制计数来生成全排列。 - **递减进位制数法**:与递进出位制数法相反,从最大值逐步递减。 - **...

    字典序、邻位对换、递归递增进位制数法、递归的递减进位制数法生成全排列

    字典序、邻位对换、递归递增进位制数法、递归的递减进位制数法生成全排列。除递归地增是O(n·n!)外,其余三个都是O(n!)。main函数是计算1——12生成全排列的运行时间。

    全排列——递归排序和字典序列

    本文将详细介绍两种实现全排列的方法:递归排列和字典序排列,并通过具体的代码示例来加深理解。 #### 一、递归排列 递归排列是一种直观且易于实现的方法。其基本思路是从集合中依次选取每一个元素作为排列的第一...

    vc++全排列之字典序法

    在全排列问题中,字典序法意味着生成的排列应按照从小到大的字典顺序排列。 首先,我们需要理解全排列的基本概念。给定一个数组或字符串,全排列是指生成所有可能的n个元素的排列,其中n是数组或字符串的长度。例如...

    n个数的全排列

    全排列生成算法是解决此类问题的关键。一种常见的生成方法是回溯法,也称为深度优先搜索(DFS)。在DFS中,我们从第一个位置开始,尝试放置每个可能的数字,如果当前位置的数字选择完毕,就回溯到上一个位置选择下一...

    组合数学全排列算法(转)

    - **原理**:该算法基于字典序的排列生成方式,可以生成按字典序排序的全排列序列。 - **优点**:生成的序列有序,便于理解和验证。 - **缺点**:当排列数量非常大时,可能需要较大的计算资源。 #### 全排列算法...

    Java全排列算法字典序下的下一个排列讲解

    Java全排列算法字典序下的下一个排列讲解 在计算机科学中,全排列算法是一种非常重要的算法,它可以将一个数组或集合中的所有元素排列成不同的顺序。今天,我们将讨论如何使用Java实现全排列算法,并且讨论字典序下...

Global site tag (gtag.js) - Google Analytics