java數(shù)組排列組合問題匯總
面試或筆試中,多次遇到以下4個關(guān)于排列組合的手撕算法,這里做個筆記,方法日后查閱:
1. 無重復(fù)元素的數(shù)組,求全排列;
2. 有重復(fù)元素的數(shù)組,求全排列;
3. 無重復(fù)元素的數(shù)組,求組合【子集】;
4. 有重復(fù)元素的數(shù)組,求組合;
以上四類題,可以用統(tǒng)一的模板實現(xiàn),如下所示:
/*
*【組合&&排列】
*把一個數(shù)組里的數(shù)組合全部列出,比如1和2列出來為1,2,12,21.
*這個題目可以擴(kuò)展成四個:
*1.無重復(fù)數(shù)字的數(shù)組,求組合
*2.有重復(fù)數(shù)字的數(shù)組,求組合
*3.無重復(fù)數(shù)字的數(shù)組,求全排列
*4.有重復(fù)數(shù)字的數(shù)組,求全排列
*【通用思路(遞歸)】:
*定義一個函數(shù):從候選集candicate中選取一個組合prefix
*每次從候選集candicate中remove一個數(shù),并加入前綴prefix,打印prefix;
*再遞歸從新的candicate中remove下一個數(shù),并加入prefix
*【對于重復(fù)的控制】
*采用hashset保存prefix,打印之前,判斷hashset中是否包含當(dāng)前生成的prefix,
*沒有則打印,并加入hashset;有則不打印
*【組合--》排列】
*只需在打印前加一個判斷:若候選集candicate為空,表示遍歷完一次,生成一個排列,可打印
*/
package xh.offer.practice;
import java.util.Arrays;
import java.util.HashSet;
import java.util.LinkedList;
import java.util.List;
public class listAllGroup{
public static void main(String[] args) {
String [] array = {"1","2"};
String [] repeate = {"1","2","1"};
listAllGroup test = new listAllGroup();
System.out.println("**********no repeate list*******");
test.listAllNoRepeate(Arrays.asList(array),"");//初始化prefix = ""
System.out.println("**********repeate list*******");
HashSet<String> noRepeateSet = new HashSet<String>();
test.listAllRepeate(Arrays.asList(repeate), "", noRepeateSet);
System.out.println("**************no repeate premutation********************");
test.premutationNoRepeate(Arrays.asList(array),"");
System.out.println("*********************repeate premutation**********************");
HashSet<String> repeateSet = new HashSet<String>();
test.premutationRepeate(Arrays.asList(repeate),"", repeateSet);
}
//無重復(fù)的組合
public void listAllNoRepeate(List<String> candicate,String prefix){
if(prefix.length() != 0)
System.out.println(prefix);//結(jié)果長度不為0,則打印輸出該組合
for(int i = 0;i < candicate.size();i++){
//將list轉(zhuǎn)換成linklist鏈表,方便操作
List<String> tempList = new LinkedList<String>(candicate);
//templist減少一個數(shù)字,并暫存templist中去除的數(shù)字
String tempString = (String) tempList.remove(i);
//遞歸
listAllNoRepeate(tempList,prefix + tempString);
}
}
//有重復(fù)的組合,加入hashset
public void listAllRepeate(List<String> candicate,String prefix,HashSet<String> res){
if(prefix.length() != 0 && !res.contains(prefix)){
System.out.println(prefix);
res.add(prefix);
}
for(int i = 0;i < candicate.size();i++){
List<String> tempList = new LinkedList<String>(candicate);
String tempString = tempList.remove(i);
listAllRepeate(tempList, prefix+tempString, res);//遞歸
}
}
//無重復(fù)的全排列,加入判斷candicate.size() == 0
public void premutationNoRepeate(List<String> candicate,String prefix){
if(candicate.size() == 0){
System.out.println(prefix);
}
for(int i = 0;i < candicate.size();i++){
List<String> tempList = new LinkedList<String>(candicate);
String tempString = tempList.remove(i);
premutationNoRepeate(tempList,prefix+tempString);
}
}
//有重復(fù)的全排列,加入hashset輔助判斷輸出
public void premutationRepeate(List<String> candicate,String prefix,HashSet<String> res) {
if(candicate.size() == 0 && !res.contains(prefix)){
System.out.println(prefix);
res.add(prefix);
}
for(int i = 0;i < candicate.size();i++){
List<String> tempList = new LinkedList<String>(candicate);
String tempString = tempList.remove(i);
premutationRepeate(tempList, prefix+tempString, res);
}
}
}
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Java Selenium實現(xiàn)多窗口切換的示例代碼
這篇文章主要介紹了Java Selenium實現(xiàn)多窗口切換的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09
Java 多線程學(xué)習(xí)詳細(xì)總結(jié)
本文主要介紹 Java 多線程的知識資料,這里整理了詳細(xì)的多線程內(nèi)容,及簡單實現(xiàn)代碼,有需要的朋友可以參考下2016-09-09
深入淺析Java中Static Class及靜態(tài)內(nèi)部類和非靜態(tài)內(nèi)部類的不同
上次有朋友問我,java中的類可以是static嗎?我給他肯定的回答是可以的,在java中我們可以有靜態(tài)實例變量、靜態(tài)方法、靜態(tài)塊。當(dāng)然類也可以是靜態(tài)的,下面小編整理了些關(guān)于java中的static class相關(guān)資料分享在腳本之家平臺供大家參考2015-11-11
MyBatis-Plus多數(shù)據(jù)源的示例代碼
本文主要介紹了MyBatis-Plus多數(shù)據(jù)源的示例代碼,包括依賴配置、數(shù)據(jù)源配置、Mapper 和 Service 的定義,具有一定的參考價值,感興趣的可以了解一下2024-05-05
使用@RequestParam設(shè)置默認(rèn)可以傳空值
這篇文章主要介紹了使用@RequestParam設(shè)置默認(rèn)可以傳空值的操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-08-08

