LintCode 15.全排列

学习了怎么写简单的递归DPS,没有去琢磨非递归

import org.junit.Test;

import java.util.ArrayList;
import java.util.List;

public class Permute {
    /**
     * @param nums: A list of integers.
     * @return: A list of permutations.
     * <p>
     * 15. 全排列
     * 给定一个数字列表,返回其所有可能的排列。
     * <p>
     * 样例
     * 给出一个列表[1,2,3],其全排列为:
     * <p>
     * [
     * [1,2,3],
     * [1,3,2],
     * [2,1,3],
     * [2,3,1],
     * [3,1,2],
     * [3,2,1]
     * ]
     * 挑战
     * 使用递归和非递归分别解决。
     * <p>
     * 注意事项
     * 你可以假设没有重复数字。
     */
    public List<List<Integer>> permute(int[] nums) {
        // write your code here
        List<List<Integer>> result = new ArrayList<>();
        List<Integer> list = new ArrayList<>();
        if (nums == null) {
            return result;
        }
        if (nums.length == 0) {
            result.add(list);
            return result;
        }
        boolean[] color = new boolean[nums.length];//存放color节点
        for (int i = 0; i < nums.length; i++) {
            color[i] = false;
        }
        dfs(result, list, nums, color);
        return result;
    }

    public void dfs(List<List<Integer>> result, List<Integer> list, int[] nums,
                    boolean[] color) {
        if (list.size() == nums.length) {
            result.add(new ArrayList<>(list));
            return;
        }
        for (int i = 0; i < nums.length; i++) {
            if (color[i] == false) {
                list.add(nums[i]);
                color[i] = true;
                dfs(result, list, nums, color);
                color[i] = false;//回退到上一步后要将本位置的访问状态置回false
                list.remove(list.size() - 1);//将下面添加的剪掉
            }
        }
    }

    @Test
    public void testPermute() {
        List<List<Integer>> result = permute(new int[]{1, 2, 3, 4});
        for (int i = 0; i < result.size(); i++) {
            System.out.println(result.get(i).toString());
        }
    }
}
posted @ 2018-08-08 15:06  wei1  阅读(82)  评论(0编辑  收藏  举报