剑指Offer--全排列递归思路 前言 全排列,full permutation, 可以利用二叉树的遍历实现.二叉树的递归遍历,前中后都简洁的难以置信,但是都有一个共同特点,那就是一个函数里包含两次自身调用. 所以,如果一个递归函数中包含了两次自身调用,那么这类问题就是归纳成二分问题.也就是to be or not to be , is the problem.如果一个使用相同手段并且每一个点上可分为两种情况的问题,基本都可以转化为递归问题.当然,如果是有三个孩子的树,那么我们可能需要在一个递归
说明,本文全文代码均用dart语言实现. 求一个集合S中m个元素的所有排列情况,并打印,非常适合用递归的思路实现.本文给出了两种实现方法,一种是给定的填充排列数组长度是固定的,一种是可变长度的.两种方法主要思路是一样的,只是实现细节上略有差异.具体代码如下: void permute<E>(Set<E> s, int m) { if (m < 0 || m > s.length) throw StateError('m is not in [0, ${s.length}