JAVA用递归实现全排列算法的示例代码

作者:心拍数#0822 时间:2023-06-01 09:09:58 

求一个n阶行列式,一个比较简单的方法就是使用全排列的方法,那么简述以下全排列算法的递归实现。

首先举一个简单的例子说明算法的原理,既然是递归,首先说明一下出口条件。以[1, 2]为例

首先展示一下主要代码(完整代码在后面),然后简述


//对数组array从索引为start到最后的元素进行全排列  public void perm(int[]array,int start) {
   if(start==array.length) { //出口条件
     for(int i=0;i<array.length;i++) {
//        this.result[row][i] = array[i];
       System.out.print(array[i]+" ");
     }
//      System.out.print(++this.row+": ");
//      System.out.println("逆序数是:"+ this.against(array));
     System.out.print('\n');
   }
   else {
     for(int i=start;i<array.length;i++) {
       swap(array,start,i); //交换数组array中索引为start与i的两个元素
       perm(array,start+1);
       swap(array,start,i);
     }
   }
 }

首先数组[1, 2]分析,在else的部分

调用了swap(array, 0,0)然后调用perm(array, 1)

调用swap(array, 1, 1)然后调用perm(array, 2),然后在if里面2 == 2成立,打印[1, 2]

调用swap(array, 1,1)把之前交换的swap(array,1,1)复原,虽然看起来没有变化

回到上一层

调用swap(array, 0, 1) 然后调用perm(array, 1)

调用swap(array, 1, 1)然后调用perm(array, 2),然后在if里面2 == 2成立,打印[2, 1]

调用swap(array, 1,1)把之前交换的swap(array,1,1)复原,虽然看起来没有变化

回到上一层

跳出循环,程序结束。

这就是对[1, 2]的全排列。

那么放到一般情况,[1, 2, 3]呢?

调用了swap(array, 0,0)然后调用perm(array, 1)

然后对[2, 3]进行全排列,其中输出[1,2,3], [1, 3, 2]

再次调用swap(array,0,0)复原

调用了swap(array, 0,1)然后调用perm(array, 1)

然后对[1,3]进行全排列,输出[2,1,3], [2,3,1]

再次调用swap(array,0,1)复原

调用了swap(array, 0,2)然后调用perm(array, 1)

然后对[2,1]进行全排列,输出[3,2,1], [3,1,2]

再次调用swap(array,0,2)复原

更高阶的就是同理了!

那么我们的代码如下:


package matrix;

import java.util.Arrays;

public class Permutation {

/**
  * author:ZhaoKe
  * college: CUST
  */
 //当前打印的第几个排列
 private int row = 0;
 //存储排列的结果
 private int[][] result;

public Permutation(int[] array) {
   this.row = 0;
   this.result = new int[this.factor(array.length)][array.length];
 }

public int[][] getResult() {
   return result;
 }

//求数组a的逆序数
 public int against(int a[]) {
   int nn = 0;
   for (int i = 0; i < a.length-1; i++) {
     for (int j = i+1; j<a.length; j++) {
       if (a[i] > a[j]) {
         nn++;
       }
     }
   }
   return nn;
 }

//排列数
 public int factor(int a) {
   int r = 1;
   for (; a>=1; a--) {
     r *= a;
   }
   return r;
 }

public void perm(int[]array,int start) {
   if(start==array.length) {
     System.out.print((this.row+1)+": ");
     for(int i=0;i<array.length;i++) {
       this.result[row][i] = array[i];
       System.out.print(array[i]+" ");
     }
     this.row++;
     System.out.println("逆序数是:"+ this.against(array));
     System.out.print('\n');
   }
   else {
     for(int i=start;i<array.length;i++) {
       swap(array,start,i);
       perm(array,start+1);
       swap(array,start,i);
     }
   }
 }

public void swap(int[] array,int s,int i) {
   int t=array[s];
   array[s]=array[i];
   array[i]=t;
 }

public void printResult() {
   for (int i = 0; i < result.length; i++) {
       System.out.println(Arrays.toString(this.result[i]));
   }
 }

public static void main(String[] args) {
   int[] a = {1, 2, 3};
   Permutation p = new Permutation(a);
   p.perm(a,0);
   p.printResult();
 }
}

运行该程序结果如下:

1: 1 2 3 逆序数是:0
 
2: 1 3 2 逆序数是:1
 
3: 2 1 3 逆序数是:1
 
4: 2 3 1 逆序数是:2
 
5: 3 2 1 逆序数是:3
 
6: 3 1 2 逆序数是:2
 
[1, 2, 3]
[1, 3, 2]
[2, 1, 3]
[2, 3, 1]
[3, 2, 1]
[3, 1, 2]

来源:https://www.cnblogs.com/zhaoke271828/p/12530031.html

标签:JAVA,递归,全排列,算法
0
投稿

猜你喜欢

  • java两个integer数据判断相等用==还是equals

    2021-06-14 00:46:52
  • Tomcat内存溢出分析及解决方法

    2023-11-12 23:24:47
  • Java连接redis及基本操作示例

    2023-12-07 03:27:03
  • Android应用内调用第三方应用的方法

    2023-02-03 11:11:32
  • Android自定义带圆点的半圆形进度条

    2023-08-05 07:47:15
  • TableLayout(表格布局)基础知识点详解

    2023-05-30 01:12:42
  • Java实现顺时针输出螺旋二维数组的方法示例

    2022-02-03 00:11:41
  • Android TabWidget底部显示效果

    2022-08-05 10:54:40
  • spring基于注解配置实现事务控制操作

    2021-12-07 11:58:24
  • java 中堆内存和栈内存理解

    2023-04-23 19:24:05
  • java实现查找替换功能

    2021-12-15 00:46:50
  • c#基于winform制作音乐播放器

    2023-08-06 11:55:08
  • C#线程倒计时器源码分享

    2023-08-16 07:23:36
  • Android WindowManger的层级分析详解

    2023-08-05 23:51:40
  • C#下载歌词文件的同步和异步方法

    2023-04-11 22:46:49
  • 全面详解Maven打包及其相关插件和高级特性

    2022-03-03 21:10:00
  • Java使用单链表实现约瑟夫环

    2022-02-07 01:19:59
  • Java 获取Web项目相对webapp地址的实例

    2022-07-03 17:46:00
  • Android ListView实现简单列表功能

    2022-11-29 12:35:18
  • Springboot与Maven多环境配置的解决方案

    2023-11-29 08:53:58
  • asp之家 软件编程 m.aspxhome.com