Решето Эратосфена — различия между версиями
Bochkarev (обсуждение | вклад) (Новая страница: «'''Решето Эратосфена''' — алгоритм нахождения всех простых чисел до некото…») |
Bochkarev (обсуждение | вклад) |
||
Строка 1: | Строка 1: | ||
− | '''Решето Эратосфена''' — алгоритм нахождения всех [[ | + | '''Решето Эратосфена''' — алгоритм нахождения всех [[простые числа|простых чисел]] до некоторого целого числа <tex>n</tex>, который приписывают древнегреческому математику Эратосфену Киренскому. |
== Алгоритм == | == Алгоритм == |
Версия 01:23, 12 октября 2010
Решето Эратосфена — алгоритм нахождения всех простых чисел до некоторого целого числа , который приписывают древнегреческому математику Эратосфену Киренскому.
Алгоритм
Для нахождения всех простых чисел не больше заданного числа n, следуя методу Эратосфена, нужно выполнить следующие шаги:
- Выписать подряд все целые числа от двух до n (2, 3, 4, …, n).
- Пусть переменная p изначально равна двум — первому простому числу.
- Вычеркнуть из списка все числа от 2p до n, делящиеся на p (то есть, числа 2p, 3p, 4p, …)
- Найти первое не вычеркнутое число, большее чем p, и присвоить значению переменной p это число.
- Повторять шаги 3 и 4 до тех пор, пока p не станет больше, чем n
- Все не вычеркнутые числа в списке — простые числа.
На практике, алгоритм можно немного улучшить следующим образом. На шаге №3, числа можно вычеркивать, начиная сразу с числа
, потому что все составные числа меньше его уже будут вычеркнуты к этому времени. И, соответственно, останавливать алгоритм можно, когда станет больше, чем .