上一篇说了使用位运算来进行子集输出,这里使用回溯的方法来进行排序. 回溯的思想,我的理解就是: 把解的所有情况转换为树或者图,然后用深度优先的原则来对所有的情况进行遍历解析. 当然,因为问题中会包涵这各种各样的限制条件,我们可以用这些限制条件去减少遍历的分支. 其实,比较著名的就是0-1背包问题,这个背包问题之后再说,这里先看排列组合. 假设我们的数组为[6,7,8],依然使用0来表示当前数字不存在,用1来表示当前数字存在,我们就可以画出这样一个树: 这里使用递归来生成对应的flag标记,重点是…