Статья подготовлена для студентов курса «Алгоритмы для разработчиков» в образовательном проекте OTUS. Что такое решето Эратосфена, знает сегодня, пожалуй, любой школьник, интересующийся математикой. Но не всякий знает, какова алгоритмическая сложность этого «просеивателя». Напомним условие задачи Необходимо найти все простые числа, меньшие или равные заданному числу N. Запишем в ряд все числа от 1 до N и будем вычёркивать оттуда все числа, кратные двойке, но больше двойки, затем, все числа, кратные тройке, но больше тройки и т. д. Если число уже вычеркнуто, пропускаем его и переходим к следующему. Так мы продолжаем, пока не дойдем до N. В итоге у нас останутся невычеркнутыми только простые числа. Почему так? Потому что оставшиеся числа не делятся ни на что, кроме самих себя и единицы. Это легко доказать методом от противного. Допустим, осталось число n и оно делится на некоторое k, такое, что 1 < k < n. Значит, оно должно было быть вычеркнуто, когда вычёркивали числа, делящиеся на