日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

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

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

求一個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]

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

標簽: Java
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产伊人久久| 久久精品一区二区不卡| 亚洲va久久| 亚洲激情婷婷| 99视频一区| 蜜臀久久99精品久久久画质超高清| 亚洲一区二区网站| 性欧美精品高清| 亚洲精品一级| 国产欧美一区二区三区国产幕精品 | 国产精品极品| 国产精品v亚洲精品v日韩精品| 乱一区二区av| 亚洲天堂资源| 成人av二区| 美美哒免费高清在线观看视频一区二区| 蜜臀av一区二区在线免费观看 | 在线观看一区| 国产欧美一区| 久久久久久色 | 婷婷综合社区| 蘑菇福利视频一区播放| 日韩国产在线一| 国产精品蜜月aⅴ在线| 美女尤物国产一区| 欧美精品高清| 视频一区视频二区中文| 亚洲精品在线国产| 免费在线观看一区| 久久婷婷亚洲| 亚洲+小说+欧美+激情+另类| 国产精品日韩精品在线播放| av综合电影网站| 男女男精品网站| 国产精品第一| 婷婷成人综合| 亚洲精品一二三**| 亚洲一区资源| 一区福利视频| 久久精品 人人爱| 国产在线观看www| 亚洲免费影院| 免费亚洲婷婷| 亚洲女人av| 精品国产麻豆| 蜜臀av性久久久久蜜臀aⅴ流畅 | 日本不卡视频在线观看| 久久av综合| 极品裸体白嫩激情啪啪国产精品| 日韩成人精品一区二区三区| 天堂√8在线中文| 亚洲精品国模| 日韩伦理在线一区| 日韩精品中文字幕一区二区| 日韩欧美一区二区三区免费看| 男女性色大片免费观看一区二区| 免费在线欧美黄色| 99香蕉国产精品偷在线观看| 国产精品xxxav免费视频| 国产真实久久| 久久99精品久久久野外观看| 自拍日韩欧美| 97精品国产福利一区二区三区| 伊人久久大香伊蕉在人线观看热v| 精品三级在线| 久久国产精品久久久久久电车| 美女视频黄久久| 亚洲日本在线观看视频| 日韩一区三区| 国产精品成人**免费视频| 日韩午夜黄色| 国产h片在线观看| 欧美亚洲一级| 久久亚洲二区| 国内激情久久| 成人在线免费观看网站| 中文字幕一区二区av| 欧美freesex黑人又粗又大| 欧美日韩一区二区三区不卡视频 | 国产日韩一区二区三免费高清 | 日韩在线二区| 国产精品对白久久久久粗| 先锋影音国产一区| 久久久久蜜桃| 精品国产乱码久久久| 日韩一区二区三区免费视频| 亚洲精品网址| 亚洲精品一区三区三区在线观看| 国产日本亚洲| 男人操女人的视频在线观看欧美| 久久国产中文字幕| 国产专区精品| 欧美国产免费| 国产精品亚洲综合色区韩国 | 欧美精品观看| 综合亚洲色图| 日韩一区二区免费看| 久久久久免费av| 麻豆国产在线| 国产精品蜜芽在线观看| 欧美激情视频一区二区三区免费 | 精品三级久久| 国产一区国产二区国产三区| 日韩高清不卡一区| 综合欧美精品| 午夜精品福利影院| 欧美中文日韩| 午夜亚洲福利| 日韩在线黄色| 亚洲精品观看| 亚久久调教视频| 天堂av一区| 亚洲精品自拍| 日韩国产在线一| 欧美日韩亚洲一区| 欧美亚洲一区二区三区| 日韩高清在线一区| 日本国产欧美| 欧美日韩一区二区高清| 日本强好片久久久久久aaa| 日韩福利视频导航| 欧美一区影院| 日韩不卡在线观看日韩不卡视频| 亚洲三级网站| 日韩av资源网| 国产欧美三级| 国产成人免费精品| 亚洲伊人av| 国产91久久精品一区二区| 999精品一区| 99久久久久久中文字幕一区| 免费久久精品| 午夜在线精品| 日本成人一区二区| 久久99视频| 欧美日韩国产观看视频| 久久亚洲精品中文字幕蜜潮电影| 女主播福利一区| 国产亚洲一区在线| 日本不卡一二三区黄网| 国产欧美在线| 日韩av专区| 尤物在线精品| 亚洲久久视频| 久久精品天堂| 四虎影视精品| 国产精品88久久久久久| 奶水喷射视频一区| 日韩成人一级| 亚洲3区在线| 久久久久久亚洲精品美女| 久久久久久久久丰满| 在线成人直播| 欧美日一区二区| 老鸭窝亚洲一区二区三区| 青草久久视频| 丰满少妇一区| 婷婷综合亚洲| 欧美日韩1区2区3区| 国产精品成人a在线观看| 91av亚洲| 免费日韩av| 六月丁香综合在线视频| 亚洲高清av| 日韩国产一区二| a国产在线视频| 一区二区三区国产在线| 久久国产精品美女| 久久一区二区三区喷水| 亚洲欧美在线综合| 国产精品高颜值在线观看| 尹人成人综合网| 国产免费av一区二区三区| 日韩理论片av| 91精品丝袜国产高跟在线| av中文字幕在线观看第一页| 国产亚洲亚洲| 久久精品国产免费| 夜夜嗨一区二区三区| 国产精品色婷婷在线观看| 国产伊人精品| 国产精品久久久久久久久免费高清| 九九精品调教| 国产亚洲一区二区三区啪| 中文字幕系列一区| 欧美一级久久| 久久亚洲国产| 久久不见久久见国语| 国产午夜精品一区二区三区欧美| 久久不见久久见国语| 在线视频免费在线观看一区二区| 国产精品1luya在线播放| 欧美福利在线| 欧美aa在线视频| 石原莉奈在线亚洲三区| 欧美天堂视频| 国产精品啊啊啊| 免费久久99精品国产| 欧美一级鲁丝片| 国产精品极品在线观看|