鱼C论坛

 找回密码
 立即注册
查看: 10150|回复: 25

题目24:0,1,2,3,4,5,6,7,8,9的第100万个字典排列是什么?

[复制链接]
发表于 2017-8-24 17:32:05 | 显示全部楼层
  1. def f(n):
  2.     if n == 1:
  3.         return 1
  4.     return n * f(n-1)

  5. m = 1000000  # 第几个序列
  6. w = 9  # 位数
  7. temp = 0
  8. i = 0
  9. a = list('0123456789')
  10. b = []
  11. while True:
  12.     if f(w) < m:
  13.         i += 1
  14.         m -= f(w)
  15.         continue
  16.     else:
  17.         w -= 1
  18.         b.append(a[i])
  19.         a.remove(a[i])
  20.         i = 0
  21.     if w == 0 :
  22.         break
  23. print(''.join(b+a))
复制代码


%time %run ol024.py
2783915460
Wall time: 3 ms
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-11-5 06:47

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表