Просто чтобы уточнить, это не домашняя задача:)
Я хотел найти простые числа для математического приложения, которое я строю, и наткнулся на Сито Эратосфена подход.
Я написал его реализацию на Python.Но это ужасно медленно.Например, если я хочу найти все простые числа менее 2 миллионов.Это займет> 20 минут.(Я остановил это в этот момент).Как я могу ускорить это?
def primes_sieve(limit):
limitn = limit+1
primes = range(2, limitn)
for i in primes:
factors = range(i, limitn, i)
for f in factors[1:]:
if f in primes:
primes.remove(f)
return primes
print primes_sieve(2000)
ОБНОВЛЕНИЕ: Я закончил профилированием этого кода и обнаружил, что довольно много времени было потрачено на удаление элемента из списка.Вполне понятно, учитывая, что он должен пройти весь список (в худшем случае), чтобы найти элемент, а затем удалить его и затем перенастроить список (может быть, какая-то копия продолжается?).Во всяком случае, я вычеркнул список для словаря.Моя новая реализация -
def primes_sieve1(limit):
limitn = limit+1
primes = dict()
for i in range(2, limitn): primes[i] = True
for i in primes:
factors = range(i,limitn, i)
for f in factors[1:]:
primes[f] = False
return [i for i in primes if primes[i]==True]
print primes_sieve1(2000000)