Existe uma maneira mais concisa, eficiente ou simplesmente pitônica de fazer o seguinte?
def product(list):
p = 1
for i in list:
p *= i
return p
EDITAR:
Na verdade, acho que isso é marginalmente mais rápido do que usar operator.mul:
from operator import mul
# from functools import reduce # python3 compatibility
def with_lambda(list):
reduce(lambda x, y: x * y, list)
def without_lambda(list):
reduce(mul, list)
def forloop(list):
r = 1
for x in list:
r *= x
return r
import timeit
a = range(50)
b = range(1,50)#no zero
t = timeit.Timer("with_lambda(a)", "from __main__ import with_lambda,a")
print("with lambda:", t.timeit())
t = timeit.Timer("without_lambda(a)", "from __main__ import without_lambda,a")
print("without lambda:", t.timeit())
t = timeit.Timer("forloop(a)", "from __main__ import forloop,a")
print("for loop:", t.timeit())
t = timeit.Timer("with_lambda(b)", "from __main__ import with_lambda,b")
print("with lambda (no 0):", t.timeit())
t = timeit.Timer("without_lambda(b)", "from __main__ import without_lambda,b")
print("without lambda (no 0):", t.timeit())
t = timeit.Timer("forloop(b)", "from __main__ import forloop,b")
print("for loop (no 0):", t.timeit())
me dá
('with lambda:', 17.755449056625366)
('without lambda:', 8.2084708213806152)
('for loop:', 7.4836349487304688)
('with lambda (no 0):', 22.570688009262085)
('without lambda (no 0):', 12.472226858139038)
('for loop (no 0):', 11.04065990447998)
list
como um nome de variável ...
+
desse tipo de lista (da mesma forma para product / *
). Agora percebo que o Python é digitado dinamicamente, o que dificulta as coisas, mas esse é um problema resolvido em linguagens sãs com sistemas de tipos estáticos como Haskell. Mas Python
só permite sum
trabalhar com números de qualquer maneira, já sum(['a', 'b'])
que nem funciona, então eu digo novamente que 0
faz sentido para sum
e 1
para o produto.
reduce
respostas aumentam aTypeError
, enquanto afor
resposta do loop retorna 1. Esse é um erro nafor
resposta do loop (o produto de uma lista vazia não é mais 1 do que 17) ou 'tatu').