从Python Problem Set这三个函数可以正常工作,但它们需要每次执行一个函数才能移到下一个函数以获得最终结果。有没有办法从全部三个中获得结果,而无需单独查询每个结果?合并功能以减少查询
>>> import itertools
>>> def prime_factors(value):
if value > 3:
for this in itertools.chain(iter([2]), xrange(3,int(value ** 0.5)+1, 2)):
if this*this > value: break
while not (value % this):
if value == this: break
value /= this
yield this
yield value
>>> prime_factors(315)
generator object prime_factors at 0x01182468>
>>> def prime_factors_mult(n):
res = list(prime_factors(n))
return sorted([fact, res.count(fact)] for fact in set(res))
>>> prime_factors_mult(315)
[[3, 2], [5, 1], [7, 1]]
>>> def totient(n):
from operator import mul
if n == 1: return 1
return reduce(mul, [(p-1) * p**(m-1) for p,m in prime_factors_mult(n)])
>>> totient(315)
144
不完全确定您的意思是“从三个中获取结果而不必逐个查询每个结果”。你的意思是按顺序打三个电话吗?如果是这样,你可以创建一个函数来调用它们中的三个,并返回一个数组(例如)和结果。我有没有错过这一点? – pcalcao
等等,这是欧拉总数(phi)函数吗? – Blender
我会做的第一件事是缓存素数列表,如果需要更大的素数则扩展它。这会显着加快对'prime_factors'的调用,并且如果只需要''totient'值,可能会加快速度。 – 9000