|
发表于 2020-11-11 17:13:22
|
显示全部楼层
我就注释一下上面那位的代码吧:
from functools import reduce
fun = lambda x, y: 10 * x + y
M = 1 # 由于两数相加最多只能进1位
for S in range(8, 10): # S + 1 +1/0 >9 即 s可以是 8或9;这里我们用集合形式 set() 写出来。集合没有重复元素,E不可能与S,M重复,故减去SM
for E in set(range(10)) - {S, M}:
for N in set(range(10)) - {S, E, M}:
for D in set(range(10)) - {S, E, N, M}:
for O in set(range(10)) - {S, E, N, D, M}:
for R in set(range(10)) - {S, E, N, D, O, M}:
for Y in set(range(10)) - {S, E, N, D, O, R, M}:
SEND = reduce(fun, (S, E, N, D)) # 这么看就简单了,其实就等价于 SEND = S*1000 + E*100 + N*10 + D
MORE = reduce(fun, (M, O, R, E)) # 同理
MONEY = reduce(fun, (M, O, N, E, Y))
if SEND + MORE == MONEY: # 最后循环判断了下而已
print('%d + %d = %d'%(SEND, MORE, MONEY))
exit() |
|