由于在排版系统中的需要今天写了一个可以列举出全排列的AllPermutation类(主要是按照字典序的顺序):
import java.util.Arrays;
public class AllPermutation
{
int elements[];
public AllPermutation(int[] elements)
{
super();
this.elements = elements;
}
public int[] next()//according to the order of dictionary
{
int posA = -1;
for (int i = elements.length - 1; i >= 1; i--)
{
if (elements[i] > elements[i - 1])
{
posA = i - 1;
break;
}
}
if (posA == -1)//is the biggest
{
System.out.println("no more permutaion!");
return null;
}
int posB = posA + 1;//save another position
for (int j = elements.length - 1; j >= posB; j--)
{
if (elements[j] > elements[posA] && elements[j] < elements[posB])
{
posB = j;
}
}
swap(posA, posB);
Arrays.sort(elements, posA + 1, elements.length);//ascending sort
int[] next = new int[elements.length];
System.arraycopy(elements, 0, next, 0, elements.length);//copy
return next;
}
private void swap(int i, int j)
{
// TODO Auto-generated method stub
int temp = elements[i];
elements[i] = elements[j];
elements[j] = temp;
}
}
使用时:
AllPermutation permutation =new AllPermutation(new int[]{1,2,3,4});
int[] temp=null;
while((temp=permutation.next())!=null)
{
for (int index = 0; index < temp.length; index++)
{
int j = temp[index];
System.out.print(j+",");
}
System.out.println("");
}
输出结果 写道
1,2,4,3,
1,3,2,4,
1,3,4,2,
1,4,2,3,
1,4,3,2,
2,1,3,4,
2,1,4,3,
2,3,1,4,
2,3,4,1,
2,4,1,3,
2,4,3,1,
3,1,2,4,
3,1,4,2,
3,2,1,4,
3,2,4,1,
3,4,1,2,
3,4,2,1,
4,1,2,3,
4,1,3,2,
4,2,1,3,
4,2,3,1,
4,3,1,2,
4,3,2,1,
no more permutaion!
分享到:
相关推荐
在实际应用中,字典序全排列可以用于各种需要按顺序列举所有可能情况的场景,如生物信息学中的基因排序、文本处理中的字符串比较等。了解并掌握这种算法对于提升编程能力、解决实际问题具有重要意义。同时,它也是对...
它涉及到将一个给定的有限序列的所有可能的元素排列情况进行列举。在C#编程语言中,实现全排列算法可以帮助开发者解决多种问题,例如组合优化、数据排序等。本篇文章将深入探讨全排列算法的原理、C#实现方法以及相关...
《智慧广场——分类列举》教学设计是一份针对小学数学课程的教学计划,主要涉及的数学概念是分类和列举,这是在解决组合问题时常用的方法。在实际教学过程中,教师通过创设情境,激发学生兴趣,引入做果盘的数学问题...
### 创新技法之列举分析法 #### 一、列举法概述 列举法是一种通过将研究对象的特点、缺点以及希望点等进行全面罗列,并在此基础上提出改进措施与创意设想的方法。这种方法有助于激发人们的创造力,从而产生新颖且...
在数学教学领域,一一列举法是一种非常实用的问题解决策略,尤其在处理组合问题时显得格外重要。一一列举法通过系统地列举所有可能的情况,帮助学生理解和掌握问题的解决过程,减少遗漏或重复。本文将以青岛版小学六...
例如列举网这样的平台,它提供了一个让人们可以自由发布信息、交流观点的空间。随着用户需求的多样化和信息发布的频繁,如何高效地管理这些内容成为了一个挑战。一些情况下,用户可能需要批量上传信息,或者定期更新...
"目录列举专家"是一款专为列举指定目录下文件而设计的系统工具,它适用于需要清晰地展示文件系统结构,例如在FTP服务器上分享文件或创建目录列表的场景。这款工具的强大之处在于其能够进行递归搜索,这意味着它不仅...
这篇教学设计聚焦于人教版初中数学九年级上册的《概率初步》章节,特别是如何运用列举法来求解概率问题。教学目标旨在帮助学生掌握利用树形图和列表法来计算两步或三步实验中随机事件发生的概率,提升他们的合作交流...
本话题聚焦于“按条件列举窗口句柄”,这涉及到编程中如何通过特定条件查找并管理窗口资源。 首先,我们要理解如何使用条件来列举窗口句柄。条件通常包括: 1. **标题**:窗口的标题文本,比如一个程序的主标题或...
这份青岛一年级数学下册的PPT课件涵盖了基础的数学概念和运算,旨在帮助学生掌握列举法、加减法、比较大小以及简单的推理能力。以下是课件中的主要知识点: 1. **列举法**:列举法是一种解决问题的方法,通过列举...
在VB(Visual Basic)编程中,列举操作系统的进程是一项常见的任务,这有助于监控系统状态、管理应用程序或进行系统分析。为了实现这一功能,VB程序员通常会利用Windows API(应用程序接口)来获取系统进程的信息。...
在08列举法(产品创意分析).pptx这一文件中,我们详细探讨了列举法如何应用于产品创新,并进一步细分为缺点列举法和希望点列举法,以更具体地指导创新实践。 首先,列举法作为一种创新思维工具,其核心在于系统性地...
java常用类的方法列举,欢迎大家下载查看
"WinCE字体列举工具"是一款专为WinCE系统设计的实用程序,其主要功能是列举并展示系统中已安装的所有可用字体。这款工具对于开发者和系统管理员来说极其有价值,因为他们需要了解系统支持的字体类型,以便在开发或...
### MFC类库详解 MFC(Microsoft Foundation Classes)是微软提供的一套基于Windows API的类库,旨在简化Windows应用程序的开发过程。MFC通过封装底层API,为开发者提供了更高级、更直观的对象模型,使得应用程序的...
"一年级下册智慧广场——用表格列举法解决问题"教学设计 本教学设计旨在帮助一年级学生学习用表格列举法解决问题,巩固画图法,学习用表格列举法解决递增递减问题。在教学过程中,教师通过循序渐进的学习方式,先让...
【创新技法-列举法】是创新思维中一种实用且直接的方法,主要用于激发创新设想和解决设计问题。列举法源于美国内布拉斯加大学教授克劳福特的属性列举法,通过系统化、程序化的思维方式,帮助克服思维定势,促进新...
【智慧广场列举教学设计】是针对青岛版小学数学六年级上册第八课时的教学内容,主要探讨了如何利用“一一列举”的策略解决简单的实际问题。本教学设计旨在培养学生的逻辑思维能力和解决问题的策略意识,同时增强他们...
在小学数学教学中,列举法作为一种基本而重要的解题策略,对于培养学生的问题分析和解决能力具有重要作用。特别是在五年级数学教学中,教师们会通过一系列具体的例题,让学生系统地学习并掌握这种方法。列举法能帮助...