Решето Эратосфена: просеиваем простые числа |
||
|
МЕНЮ Главная страница Поиск Регистрация на сайте Помощь проекту Архив новостей ТЕМЫ Новости ИИ Голосовой помощник Разработка ИИГородские сумасшедшие ИИ в медицине ИИ проекты Искусственные нейросети Искусственный интеллект Слежка за людьми Угроза ИИ Атаки на ИИ Внедрение ИИИИ теория Компьютерные науки Машинное обуч. (Ошибки) Машинное обучение Машинный перевод Нейронные сети начинающим Психология ИИ Реализация ИИ Реализация нейросетей Создание беспилотных авто Трезво про ИИ Философия ИИ Big data Работа разума и сознаниеМодель мозгаРобототехника, БПЛАТрансгуманизмОбработка текстаТеория эволюцииДополненная реальностьЖелезоКиберугрозыНаучный мирИТ индустрияРазработка ПОТеория информацииМатематикаЦифровая экономика
Генетические алгоритмы Капсульные нейросети Основы нейронных сетей Промпты. Генеративные запросы Распознавание лиц Распознавание образов Распознавание речи Творчество ИИ Техническое зрение Чат-боты Авторизация |
2019-04-02 01:45 Что такое решето Эратосфена, знает сегодня, пожалуй, любой школьник, интересующийся математикой. Но не всякий знает, какова алгоритмическая сложность этого «просеивателя». Напомним условие задачи Необходимо найти все простые числа, меньшие или равные заданному числу N. Запишем в ряд все числа от 1 до N и будем вычёркивать оттуда все числа, кратные двойке, но больше двойки, затем, все числа, кратные тройке, но больше тройки и т. д. Если число уже вычеркнуто, пропускаем его и переходим к следующему. Так мы продолжаем, пока не дойдем до N. В итоге у нас останутся невычеркнутыми только простые числа. Почему так? Потому что оставшиеся числа не делятся ни на что, кроме самих себя и единицы. Это легко доказать методом от противного. Допустим, осталось число n и оно делится на некоторое k, такое, что 1 < k < n. Значит, оно должно было быть вычеркнуто, когда вычёркивали числа, делящиеся на k. А оно у нас не вычеркнулось. Оптимизации Можно просеивать только нечётные числа, ибо чётные — заведомо составные. Можно просеивать только числа до ?N. Теперь оценим потребление памяти и вычислительную сложность этого алгоритма По памяти этот алгоритм требует O(N), потому что размер целевого массива N и никакой дополнительной памяти не используется. Оценим теперь его вычислительную сложность (интересно, что оптимизации на асимптотическую сложность не влияют, а уменьшают только коэффициент). Для каждого простого p вычёркиваем числа N / p раз. Общее число действий, которые мы производим, равно сумме: ![]() Примем как данность, что число простых чисел, меньших либо равных N, приблизительно равно N / ln N, следовательно, k-e простое число приблизительно равно k ln k. Оценим сумму: ![]() Оценим новую сумму как интеграл: ![]() Интересно, знал ли об этом Эратосфен? Материал подготовлен для студентов курса «Алгоритмы для разработчиков». Не забудьте пройти вступительное тестирование для записи на курс: Телеграм: t.me/ainewsline Источник: m.vk.com Комментарии: |
|