1.定义
在数学中,字典或词典顺序(也称为词汇顺序,字典顺序,字母顺序或词典顺序)是基于字母顺序排列的单词按字母顺序排列的方法。 这种泛化主要在于定义有序完全有序集合(通常称为字母表)的元素的序列(通常称为计算机科学中的单词)的总顺序。
对于数字1、2、3…n的排列,不同排列的先后关系是从左到右逐个比较对应的数字的先后来决定的。例如对于5个数字的排列 12354和12345,排列12345在前,排列12354在后。按照这样的规定,5个数字的所有的排列中最前面的是12345,最后面的是 54321。 [百度百科]
2.字典序算法
设 P P P是1~n的一个全排列: P = p 1 p 2 … p n P=p_1p_2\dots p_n P=p1p2…pn。则在字典序中,求这个数的下一个排列是多少?
(1)从右到左找最长的降序子列 p i + 1 … p n p_{i+1}\dots p_n pi+1…pn,记下 p i p_i pi。
(2)在序列中找比 p i p_i pi大的最右边一位 p k p_k pk,交换 p i p_i pi和 p k p_k pk。
(3)将 p k p_k pk