我已经开始研究一些 Project Euler 问题,并用一个简单的蛮力解决方案解决了第 4个问题:
def mprods(a,b):
c = range(a,b)
f = []
for d in c:
for e in c:
f.append(d*e)
return f
max([z for z in mprods(100,1000) if str(z)==(''.join([str(z)[-i] for i in range(1,len(str(z))+1)]))])
解决后,我试图让它尽可能紧凑,并得出了那个可怕的底线!
不要半途而废,我试图将mprods
函数压缩为列表理解。到目前为止,我已经提出了这些尝试:
[d*e for d,e in (range(a,b), range(a,b))]
显然完全走错了路。:-)[d*e for x in [e for e in range(1,5)] for d in range(1,5)]
这给了我[4, 8, 12, 16, 4, 8, 12, 16, 4, 8, 12, 16, 4, 8, 12, 16]
,我期望[1, 2, 3, 4, 2, 4, 6, 8, 3, 6, 9, 12, 4, 8, 12, 16]
或类似的地方。
有任何 Pythonistas 可以提供帮助吗?:)