leetcode:全排列(java回溯)

自討木趣發表於2018-12-12
package LeetCode;

import java.util.ArrayList;
import java.util.List;
/*
給定一個沒有重複數字的序列,返回其所有可能的全排列。
示例:
輸入: [1,2,3]
輸出:
[
  [1,2,3],
  [1,3,2],
  [2,1,3],
  [2,3,1],
  [3,1,2],
  //基本思想:回溯思想進行每一層迴圈
 */
public class Permute {
    public List<List<Integer>> permute(int[] nums) {
        List<List<Integer>> result=new ArrayList<>();
        List<Integer> l=new ArrayList<>();
        huisu(nums,l,result);
        return result;
    }
    public void huisu(int[] nums,List<Integer> l,List<List<Integer>> result){
        if (l.size()==nums.length){
            //指向新的一片地址空間使其變成不在跟隨l改變而改變
            result.add(new ArrayList<Integer>(l));
            return;
        }else {
            for (int i = 0; i <nums.length ; i++) {
                //判斷
                if (l.contains(nums[i]))continue;
                l.add(nums[i]);
                huisu(nums,l,result);
                //退回一格
                l.remove(l.size()-1);
            }
        }
    }
    public static void main(String[] args){
        Permute a=new Permute();
        int []b={1,2,3};
        a.permute(b);
    }
}

 

相關文章