25.02 Особые числа (простые, фибоначи, факториал, палиндромы)
Ошибка.
Попробуйте повторить позже
Напишите программу, которая ищет количество простых чисел, принадлежащих числовому отрезку .
Решение 1
Классическое неэффективное решение через перебор, которое умирает на больших диапазонах
def is_prime(n): if n == 1: return False for i in range(2, int(n ** 0.5) + 1): if n % i == 0: return False return True count = 0 for i in range(1000000, 5000000 + 1): if is_prime(i): count += 1 print(count)
Решение 2
Эффективное решение задачи с помощью алгоритма «Решето Эратосфена»
def resheto(n): a = [1] * (n + 1) a[0] = a[1] = 0 for i in range(2, int(n**0.5) + 1): if a[i]: for j in range(i, n // i + 1): a[i * j] = 0 return a print(sum(resheto(5000000)) - sum(resheto(999999)))
Специальные программы

Программа
лояльности v2.0
Приглашай друзей в Школково и получай вознаграждение до 10%!

Крути рулетку
и выигрывай призы!
Крути рулетку и покупай курсы со скидкой, которая привязывается к вашему аккаунту.

Бесплатное онлайн-обучение
Для школьников из приграничных территорий России, проживающих в ДНР, ЛНР, Херсонской, Запорожской, Белгородской, Курской, Брянской областях и Крыму.

Налоговые вычеты
Узнай, как получить налоговый вычет при оплате обучения в «Школково».

Специальное предложение
для учителей
Бесплатный доступ к любому курсу подготовки к ЕГЭ, ОГЭ и олимпиадам от «Школково». Мы с вами делаем общее и важное дело, а потому для нас очень значимо быть чем-то полезными для учителей по всей России!

Вернём деньги за курс
за твою сотку на ЕГЭ
Сдать экзамен на сотку и получить обратно деньги за подготовку теперь вполне реально!