leetcode:全排列(java回溯)

  • Post author:
  • Post category:java
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);
    }
}

 


版权声明:本文为microopithecus原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。