本帖最后由 87282374 于 2024-3-17 13:32 编辑
某个组合进行全排列,把集合中元素的所有按照一定的顺序排列起来,使用P(n, n) = n!表示n个元素全排列的个数。 例如:{1, 2, 3}的全排列为:123;132;213;231;312;321;共6个,即3!=3*2*1=6。 首先取一个元素,例如取出了1,那么就还剩下{2, 3}。 然后再从剩下的集合中取出一个元素,例如取出2,那么还剩下{3}。 以此类推,把所有可能的情况取一遍,就是全排列了,如图: 将数组看为一个集合,将集合分为两部分:0~s和s~e,其中0~s表示已经选出来的元素,而s~e表示还没有选择的元素。 perm(set, s, e) { 顺序从s~e中选出一个元素与s交换(即选出一个元素) 调用perm(set, s + 1, e) 直到s>e,即剩余集合已经为空了,输出set } 请路过的高手指点一下!
|