一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|編程技術|

服務器之家 - 編程語言 - JAVA教程 - JAVA用遞歸實現全排列算法的示例代碼

JAVA用遞歸實現全排列算法的示例代碼

2020-07-04 11:41心拍數#0822 JAVA教程

這篇文章主要介紹了JAVA用遞歸實現全排列算法的相關資料,文中示例代碼非常詳細,幫助大家更好的理解和學習,感興趣的朋友可以了解下

求一個n階行列式,一個比較簡單的方法就是使用全排列的方法,那么簡述以下全排列算法的遞歸實現。

首先舉一個簡單的例子說明算法的原理,既然是遞歸,首先說明一下出口條件。以[1, 2]為例

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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
//對數組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)復原

更高階的就是同理了!

那么我們的代碼如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
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]

以上就是JAVA用遞歸實現全排列算法的示例代碼的詳細內容,更多關于JAVA遞歸實現全排列的資料請關注服務器之家其它相關文章!

原文鏈接:https://www.cnblogs.com/zhaoke271828/p/12530031.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 亚洲欧美日韩国产一区二区精品 | 欧洲破处 | 日本韩国在线 | 亚洲乱亚洲23p女 | 亚洲精品久久麻豆蜜桃 | 91传媒制片厂果冻有限公司 | 女女性恋爱视频入口 | 韩国三级年轻小的胰子完整 | 国产精品久久久久久爽爽爽 | 楚乔传第二部免费观看全集完整版 | 国产实拍会所女技师在线 | 青青热久麻豆精品视频在线观看 | 九九大香尹人视频免费 | 波多野结衣女老师 | 久久国产综合精品欧美 | 日日艹| 欧美理论片手机在线观看片免费 | 天美蜜桃精东乌鸦传媒 | 精品无人区一区二区三区 | 国产探花在线观看 | 精品一区二区三区在线视频观看 | 亚洲免费在线观看视频 | 精品国产在天天线在线麻豆 | 大陆性出航 | 亚洲国产精品91 | 精品国产91久久久久久久a | 日本老妇乱子伦中文视频 | 波多野结衣之双方调教在线观看 | 免费欧美日韩 | 大陆国产精品视频 | 金牛网155755水心论坛黄大父母 | 99er在线视频 | 青青热久免费精品视频网站 | 欧美综合一区二区三区 | 免费看成年视频网页 | 91.prom在线观看国产 | 欧美日韩一区二区综合在线视频 | 亚洲 欧美 日韩 国产 视频 | 成人午夜毛片 | 美女被视频网站看免费入口 | 全日爱韩国视频在线观看 |