最短包含所有四位数的切分字段

2018-12-27 15:56:57 +08:00
 n031k1

我(小白一只)想生成一个包含所有四位数的字段 要求有: 切分以后每一部分在 200 个数字以内 包含了所有四位数可能出现的组合 总组数最少…

现在用 python 生成了一个 10002 位的未拆分字段…

916 次点击
所在节点    问与答
3 条回复
n031k1
2018-12-27 15:57:36 +08:00
import sys

sys.setrecursionlimit(10001)

v = ['%04d' % a for a in range(0,9999)]
e = dict([(a,[(a[1:]+b) for b in '0123456789' if a[1:] + b != a]) for a in v])


def run(n, e,used, count):
if count + 1 == len(e):
return n
used.add(n)
for i in e[n]:
if i not in used:
r = run(i, e, used, count + 1)
if r is not None:
return n[0] + r
used.remove(n)
return None


print run('0000',e,set(),0)
whileFalse
2018-12-27 19:08:09 +08:00
我脑里出现了一个四维迷宫……
n031k1
2018-12-28 15:21:57 +08:00
有没有同学救救伸手党!不行我就要动脑了!

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/521554

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX