初学算法之排列的字典序

1.定义

  在数学中,字典或词典顺序(也称为词汇顺序,字典顺序,字母顺序或词典顺序)是基于字母顺序排列的单词按字母顺序排列的方法。 这种泛化主要在于定义有序完全有序集合(通常称为字母表)的元素的序列(通常称为计算机科学中的单词)的总顺序。
  对于数字1、2、3…n的排列,不同排列的先后关系是从左到右逐个比较对应的数字的先后来决定的。例如对于5个数字的排列 12354和12345,排列12345在前,排列12354在后。按照这样的规定,5个数字的所有的排列中最前面的是12345,最后面的是 54321。

2.字典序算法

设PP是1~n的一个全排列:P=p_1p_2\dots p_nP=p1​p2​…pn​。则在字典序中,求这个数的下一个排列是多少?
(1)从右到左找最长的降序子列p_{i+1}\dots p_npi+1​…pn​,记下p_ipi​。
(2)在序列中找比p_ipi​大的最右边一位p_kpk​,交换p_ipi​和p_kpk​。
(3)将p_kpk​右侧子列倒排。

  • 例子1
    在这里插入图片描述
  • 例子2
    在这里插入图片描述
  • 例子3
    在这里插入图片描述
  • 例4 如何得到346987521的下一个
        1,从尾部往前找第一个P(i-1) < P(i)的位置
                3 4 6 <- 9 <- 8 <- 7 <- 5 <- 2 <- 1
            最终找到6是第一个变小的数字,记录下6的位置i-1
        2,从i位置往后找到最后一个大于6的数
                3 4 6 -> 9 -> 8 -> 7 5 2 1
            最终找到7的位置,记录位置为m
        3,交换位置i-1和m的值
                3 4 7 9 8 6 5 2 1
        4,倒序i位置后的所有数据
                3 4 7 1 2 5 6 8 9
        则347125689为346987521的下一个排列

3.代码的具体实现 

 

4.运行结果如下图 

 

  • 5
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值