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

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

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

瀏覽:22日期: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久久,三上悠亚国产精品一区二区三区
激情欧美日韩一区| 97国产精品| 韩国精品主播一区二区在线观看| 国产精品日本一区二区不卡视频 | 久久亚洲风情| 日韩午夜电影| 亚洲欧美日韩视频二区| 国产模特精品视频久久久久| 精品一区在线| 国产一区导航| 亚洲欧洲免费| 久久国产婷婷国产香蕉| 免费观看亚洲天堂| 麻豆成人91精品二区三区| 国产精品一区二区中文字幕| 国产欧美日韩精品一区二区免费| 91麻豆精品激情在线观看最新 | 视频一区中文| 在线国产一区二区| 视频一区国产视频| 亚洲一二三区视频| 日本伊人午夜精品| 国产激情久久| 亚洲伦乱视频| 黑丝一区二区| 亚洲综合不卡| 日韩高清一区| 精品久久久久中文字幕小说| 黑森林国产精品av| 国产一级一区二区| 国产精品一区二区中文字幕| 久久精品欧洲| 久久三级视频| 蜜桃视频一区二区| 国产调教精品| 欧美aa一级| 尹人成人综合网| 日韩精品一区二区三区免费视频 | 快she精品国产999| 欧美色综合网| 中文字幕人成乱码在线观看| 欧美成人日韩| 日日夜夜免费精品视频| 另类小说一区二区三区| 91精品久久久久久久久久不卡| 夜夜嗨网站十八久久| 青草国产精品| 日韩中文在线电影| 蜜桃久久久久久久| 精品久久久久中文字幕小说| 黑丝美女一区二区| 日韩福利视频导航| 日韩毛片在线| 日本天堂一区| 麻豆视频在线观看免费网站黄 | 久久精品动漫| 日本综合精品一区| 人人草在线视频| 亚洲日韩视频| 成人国产精品一区二区网站| 伊人成人在线视频| 国产激情综合| 亚洲中字黄色| 91欧美日韩| 午夜在线播放视频欧美| 午夜亚洲精品| 91大神在线观看线路一区| 欧美日韩一区二区国产| 水蜜桃久久夜色精品一区| 欧美日韩国产亚洲一区| 精品美女久久| 成人高清一区| 精品国产网站| 最新中文字幕在线播放| 日韩精品一区二区三区免费视频| 亚洲成av人片一区二区密柚| 麻豆国产91在线播放| 久久久久国产一区二区| 超碰在线99| 国产99久久| 国内一区二区三区| 99精品综合| 最新亚洲一区| 亚洲精品中文字幕99999| 水蜜桃精品av一区二区| 国产精品jk白丝蜜臀av小说| 国产日韩一区二区三区在线| 亚洲理论在线| 青青草国产成人99久久| 国产亚洲欧美日韩在线观看一区二区| 日本伊人午夜精品| 国产精品日韩精品中文字幕| 卡一卡二国产精品| 欧美精品91| 美女视频网站久久| 国产精品免费看| 综合日韩av| 中文字幕人成乱码在线观看 | 午夜在线视频观看日韩17c| 午夜在线视频观看日韩17c| 亚洲天堂av资源在线观看| 深夜日韩欧美| 免费人成在线不卡| 亚洲欧美日韩在线观看a三区| 亚洲欧美日本国产| 欧美1区二区| 亚洲国产不卡| 免费在线观看成人| 国产精品亚洲四区在线观看 | 福利精品一区| 美女网站视频一区| 日本不良网站在线观看| 国产精品一区二区中文字幕| 蜜桃视频一区二区三区在线观看| 香蕉成人久久| 91亚洲国产| 玖玖玖国产精品| 日本亚洲欧美天堂免费| 亚洲综合精品| 蜜桃视频在线网站| 欧美激情亚洲| 国产精品超碰| 欧美一区成人| 亚洲欧洲美洲av| 蜜臀av免费一区二区三区| 精品日韩视频| 福利一区和二区| 日本亚洲视频| 麻豆久久精品| 精品高清久久| 日韩av在线播放中文字幕| 久久黄色影视| 欧美一级二级三级视频| 日韩一区精品视频| 视频一区视频二区中文| 国产精品婷婷| 亚洲永久字幕| 国产亚洲精品久久久久婷婷瑜伽| 韩国精品主播一区二区在线观看| 久久av免费| 欧美xxxx中国| 国产精品av一区二区| 精品一区欧美| 亚洲精品亚洲人成在线观看| 欧美天堂在线| 在线人成日本视频| 午夜国产欧美理论在线播放| 老鸭窝亚洲一区二区三区| 人人爱人人干婷婷丁香亚洲| 成人在线黄色| 98精品视频| 久久久久久亚洲精品美女| 精品久久久久久久| 亚洲高清av| 日韩av一区二区在线影视| 欧美视频精品全部免费观看| 精品一区二区三区亚洲| 悠悠资源网久久精品| 美腿丝袜在线亚洲一区| 国产免费av国片精品草莓男男 | 久久wwww| 免费精品视频| 日韩av免费大片| 亚洲最大av| 国产伦一区二区三区| 午夜欧美精品| 日韩精品水蜜桃| 老色鬼精品视频在线观看播放| 91精品国产调教在线观看| 精品一区二区三区免费看| 吉吉日韩欧美| 日韩精品亚洲一区二区三区免费| 99国产精品| 婷婷激情一区| 久久国产精品美女| 免费一区二区视频| 免费成人网www| 今天的高清视频免费播放成人| 成午夜精品一区二区三区软件| 香蕉成人av| 老司机精品视频网| 日韩国产欧美一区二区三区| 亚洲免费一区二区| 亚洲激情二区| 欧美日一区二区三区在线观看国产免 | 久久久国产精品入口麻豆| 国产亚洲久久| 久久国产精品成人免费观看的软件| 噜噜噜躁狠狠躁狠狠精品视频| av在线最新| 国产在线看片免费视频在线观看| 久久国产生活片100| 久久一二三区| 久久国产99| 国产精品老牛| 先锋亚洲精品| 欧美资源在线| 性色一区二区| 久热综合在线亚洲精品| 午夜欧美在线|