DFS(深度优先搜索)
全排序类题目:
全排列:给定一个 没有重复 数字的序列,返回其所有可能的全排列。
class Solution {
public List<List<Integer>> permute(int[] nums) {
List<List<Integer>> res = new ArrayList<>();
int[] visited = new int[nums.length];
backtrack(res, nums, new ArrayList<Integer>(), visited);
return res;
}
private void backtrack(List<List<Integer>> res, int[] nums, ArrayList<Integer> tmp, int[] visited) {
if (tmp.size() == nums.length) {
res.add(new ArrayList<>(tmp));
return;
}
for (int i = 0; i < nums.length; i++) {
if (visited[i] == 1) continue;
visited[i] = 1;
tmp.add(nums[i]);
backtrack(res, nums, tmp, visited);
visited[i] = 0;
tmp.remove(tmp.size() - 1);
}
}
}
全排列 II:给定一个 有重复 数字的序列, 按任意顺序 返回所有不重复的全排列。
3. 面试题 08.07. 无重复字符串的排列组合:计算某字符串的所有排列组合,字符串每个字符 均不相同。
4. 面试题 08.08. 有重复字符串的排列组合:计算 有重复 字符串的所有排列组合,输出结果中不能有重复的字符串。
5. 剑指 Offer 38. 字符串的排列:虽然题干不太一样,但是代码可以直接 用上一题的。
6. 60. 排列序列:原名为第k个排序,难度较大,笔试更可能遇到。此题可以使用dfs+剪枝,推荐@liweiwei1419的题解:深度优先遍历 + 剪枝、有序数组模拟
7. 784. 字母大小写全排列:给定一个字符串S,通过将字符串S中的每个字母转变大小写获得一个新的字符串,返回所有可能得到的字符串集合。