亚洲免费在线视频-亚洲啊v-久久免费精品视频-国产精品va-看片地址-成人在线视频网

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

JAVA用遞歸實(shí)現(xiàn)全排列算法的示例代碼

瀏覽:6日期:2022-08-29 17:34:08

求一個(gè)n階行列式,一個(gè)比較簡(jiǎn)單的方法就是使用全排列的方法,那么簡(jiǎn)述以下全排列算法的遞歸實(shí)現(xiàn)。

首先舉一個(gè)簡(jiǎn)單的例子說(shuō)明算法的原理,既然是遞歸,首先說(shuō)明一下出口條件。以[1, 2]為例

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

//對(duì)數(shù)組array從索引為start到最后的元素進(jìn)行全排列 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('逆序數(shù)是:'+ this.against(array)); System.out.print(’n’); } else { for(int i=start;i<array.length;i++) {swap(array,start,i); //交換數(shù)組array中索引為start與i的兩個(gè)元素perm(array,start+1); swap(array,start,i); } } }

首先數(shù)組[1, 2]分析,在else的部分

調(diào)用了swap(array, 0,0)然后調(diào)用perm(array, 1)

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

調(diào)用swap(array, 1,1)把之前交換的swap(array,1,1)復(fù)原,雖然看起來(lái)沒(méi)有變化

回到上一層

調(diào)用swap(array, 0, 1) 然后調(diào)用perm(array, 1)

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

調(diào)用swap(array, 1,1)把之前交換的swap(array,1,1)復(fù)原,雖然看起來(lái)沒(méi)有變化

回到上一層

跳出循環(huán),程序結(jié)束。

這就是對(duì)[1, 2]的全排列。

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

調(diào)用了swap(array, 0,0)然后調(diào)用perm(array, 1)

然后對(duì)[2, 3]進(jìn)行全排列,其中輸出[1,2,3], [1, 3, 2]

再次調(diào)用swap(array,0,0)復(fù)原

調(diào)用了swap(array, 0,1)然后調(diào)用perm(array, 1)

然后對(duì)[1,3]進(jìn)行全排列,輸出[2,1,3], [2,3,1]

再次調(diào)用swap(array,0,1)復(fù)原

調(diào)用了swap(array, 0,2)然后調(diào)用perm(array, 1)

然后對(duì)[2,1]進(jìn)行全排列,輸出[3,2,1], [3,1,2]

再次調(diào)用swap(array,0,2)復(fù)原

更高階的就是同理了!

那么我們的代碼如下:

package matrix;import java.util.Arrays;public class Permutation { /** * author:ZhaoKe * college: CUST */ //當(dāng)前打印的第幾個(gè)排列 private int row = 0; //存儲(chǔ)排列的結(jié)果 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; } //求數(shù)組a的逆序數(shù) 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; } //排列數(shù) 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('逆序數(shù)是:'+ 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(); }}

運(yùn)行該程序結(jié)果如下:

1: 1 2 3 逆序數(shù)是:0 2: 1 3 2 逆序數(shù)是:1 3: 2 1 3 逆序數(shù)是:1 4: 2 3 1 逆序數(shù)是:2 5: 3 2 1 逆序數(shù)是:3 6: 3 1 2 逆序數(shù)是:2 [1, 2, 3][1, 3, 2][2, 1, 3][2, 3, 1][3, 2, 1][3, 1, 2]

以上就是JAVA用遞歸實(shí)現(xiàn)全排列算法的示例代碼的詳細(xì)內(nèi)容,更多關(guān)于JAVA遞歸實(shí)現(xiàn)全排列的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: Java
相關(guān)文章:
主站蜘蛛池模板: 美女三级网站 | 中国国语毛片免费观看视频 | 亚洲第一在线 | 日本不卡一区二区三区在线观看 | www.av日韩| 色综合久久加勒比高清88 | 韩国日本一级毛片免费视频 | 毛片免费全部免费观看 | 看真人一级毛片 | 国产高清一区二区三区 | 91精品久久一区二区三区 | 日韩欧美一区二区三区不卡在线 | 加勒比一本一道在线 | 久久久久久久久久久9精品视频 | 免费看孕妇毛片全部播放 | 成人亚洲天堂 | 欧美精品在线一区二区三区 | 国产一区在线看 | 欧美激情视频在线观看一区二区三区 | 日韩综合网站 | 99国产在线 | 色一欲一性一乱一区二区三区 | 视频一区视频二区在线观看 | 韩日三级视频 | 免费国产成人18在线观看 | 日韩精品一区在线观看 | 欧美午夜三级我不卡在线观看 | 欧美xxxxbbb| 国产免费人视频在线观看免费 | 5388国产亚洲欧美在线观看 | 久久综合久久美利坚合众国 | 亚洲一区www | 国产高清免费观看 | 亚洲视频国产 | 国产三级日本三级日产三 | 毛片在线播放网站 | 真正全免费视频a毛片 | 欧美日韩一区二区三区在线视频 | ccav在线永久免费看 | 亚洲精品欧美精品一区二区 | 怡红院免费全部视频在线 |