332.重新安排行程
51. N皇后
37. 解数独
总结
组合问题:N个数里面按一定规则找出k个数的集合
排列问题:N个数按一定规则全排列,有几种排列方式
切割问题:一个字符串按一定规则有几种切割方式
子集问题:一个N个数的集合里有多少符合条件的子集
棋盘问题:N皇后,解数独等等
void backtracking(参数) {
if (终止条件) {
存放结果;
return;
}
for (选择:本层集合中元素(树中节点孩子的数量就是集合的大小)) {
处理节点;
backtracking(路径,选择列表); // 递归
回溯,撤销处理结果
}
}
1.组合: 收集叶子节点,startindex
2.排列:没有startindex,从0开始,used控制path里,数有没有用到过
子集:收集节点,然后终止条件,再次for循环【递增子序列,要用集合去重】
去重:树层去重【1,2要先排序】1. used(从1开始) 2. nums[i-1]==nums[i](从startindex+1来开始) 3.集合去重