題目:
Given a collection of numbers, return all possible permutations.
For example,
[1,2,3]
have the following permutations:
[1,2,3]
, [1,3,2]
, [2,1,3]
, [2,3,1]
, [3,1,2]
, and [3,2,1]
.
題解:
這道題就用迴圈遞迴解決子問題。
因為求所有組合,這就意味著不能重複使用元素,要用visited陣列。
有因為是所有可能的組合,所以迴圈length次,就是這裡面每位都有可能有length個可能性。
正因為如此,每一層遞迴就不需要傳遞一個start點,告訴他從哪開始(因為都是從頭開始迴圈)。
程式碼如下:
1 public ArrayList<ArrayList<Integer>> permute(int[] num) {
2 ArrayList<ArrayList<Integer>> res = new ArrayList<ArrayList<Integer>>();
3 ArrayList<Integer> item = new ArrayList<Integer>();
4
5 if(num.length==0||num==null)
6 return res;
7 boolean[] visited = new boolean[num.length];
8
9 permutation_helper(num,res,item,visited);
10 return res;
11 }
12
13 public void permutation_helper(int[] num, ArrayList<ArrayList<Integer>> res, ArrayList<Integer> item,boolean[] visited){
14 if(item.size()==num.length){
15 res.add(new ArrayList<Integer>(item));
16 return;
17 }
18
19 for(int i = 0; i<num.length;i++){
20 if(!visited[i]){
21 item.add(num[i]);
22 visited[i]=true;
23 permutation_helper(num,res,item,visited);
24 item.remove(item.size()-1);
25 visited[i]=false;
26 }
27 }
28 }
2 ArrayList<ArrayList<Integer>> res = new ArrayList<ArrayList<Integer>>();
3 ArrayList<Integer> item = new ArrayList<Integer>();
4
5 if(num.length==0||num==null)
6 return res;
7 boolean[] visited = new boolean[num.length];
8
9 permutation_helper(num,res,item,visited);
10 return res;
11 }
12
13 public void permutation_helper(int[] num, ArrayList<ArrayList<Integer>> res, ArrayList<Integer> item,boolean[] visited){
14 if(item.size()==num.length){
15 res.add(new ArrayList<Integer>(item));
16 return;
17 }
18
19 for(int i = 0; i<num.length;i++){
20 if(!visited[i]){
21 item.add(num[i]);
22 visited[i]=true;
23 permutation_helper(num,res,item,visited);
24 item.remove(item.size()-1);
25 visited[i]=false;
26 }
27 }
28 }