编程语言
首页 > 编程语言> > 回溯算法

回溯算法

作者:互联网

/**
 * 46.全排列
 * 链接:https://leetcode.cn/problems/permutations/submissions/
 * 思路:回溯算法
 * */
public class Solution {
    
    private List<List<Integer>> result;
    private boolean[] marked;
    private int[] permute;
    
    public List<List<Integer>> permute(int[] nums) {
        result = new ArrayList<>();
        marked = new boolean[nums.length];
        permute = new int[nums.length];
        backtrack(nums, 0);
        return result;
    }

    private void backtrack(int[] nums, int index) {
        if (index == nums.length) {
            result.add(copy(permute));
            return;
        }
        for (int i = 0; i < nums.length; i++) {
            if (marked[i]) {
                continue;
            }
            permute[index] = nums[i];
            marked[i] = true;
            backtrack(nums, index + 1);
            marked[i] = false;
        }
    }

    private List<Integer> copy(int[] permute) {
        List<Integer> list = new ArrayList<>();
        for (int num : permute) {
            list.add(num);
        }
        return list;
    }
}

标签:nums,int,private,算法,marked,回溯,permute,result
来源: https://www.cnblogs.com/liaozibo/p/backtrack.html