Так, обработка алгоритмом числовой последовательности оставит лишь простые числа, все составные же отсеются. Рассмотрим в общих чертах работу метода. Дана упорядоченная по возрастанию последовательность натуральных чисел. Следуя методу Эратосфена, возьмем некоторое число P изначально равное 2 – первому простому числу, и вычеркнем из последовательности все числа кратные P: 2. P, 3. P, 4. P, . Далее, из получившегося списка в качестве P берется следующее за двойкой число – тройка, вычеркиваются все кратные ей числа (6, 9, 1.
По такому принципу алгоритм продолжает выполняться для оставшейся части последовательности, отсеивая все составные числа в заданном диапазоне. В приведенной таблице записаны натуральные числа от 2 до 1.
Красным помечены те, которые удаляются в процессе выполнения алгоритма «Решето Эратосфена». Программная реализация алгоритма Эратосфена потребует: организовать логический массив и присвоить его элементам из диапазона от 2 до N логическую единицу; в свободную переменную P записать число 2, являющееся первым простым числом; исключить из массива все числа кратные P2, ступая с шагом по P; записать в P следующее за ним не зачеркнутое число; повторять действия, описанные в двух предыдущих пунктах, пока это возможно. Обратите внимание: на третьем шаге мы исключаем числа, начиная сразу с P2, это связано с тем, что все составные числа меньшие P будут уже зачеркнуты. Поэтому процесс фильтрации следует остановить, когда P2 станет превышать N. Это важное замечание позволяет улучшить алгоритм, уменьшив число выполняемых операций.
Решето Эратосфена — Информатика (Арифметические алгоритмы) — Фоксфорд.Учебник.
Так будет выглядеть псевдокод алгоритма: P. Внешний цикл выполняется до тех пор, пока P2 не превысит N. Само же P изменяется с шагом P+1. Лизунова Игры Для Тигры. Внутренний цикл выполняется лишь в том случае, если на очередном шаге внешнего цикла окажется, что элемент с индексом P не зачеркнут. Именно во внутреннем цикле происходит отсеивание всех составных чисел.
Код программы на C++: 1. Поэтому уместнее использовать данный метод чем, например, наиболее тривиальный и затратный перебор делителей.
Решето Эратосфена C++Несколько месяцев назад писал решето Эратосфена на C++. Это алгоритм нахождения всех простых чисел. Если Вы начинаете изучать C++, то наверняка столкнулись или еще столкнетесь с этим алгоритмом. Это отличное задание при изучении языка. Решил выложить, может кому- то пригодится. Я сам только учусь, так что какашками не бросаться, если что- то не так Вот собственно код. Программа Решето Эратосфена.