Тема 25. Обработка целочисленной информации

25.01 Делители числа

Вспоминай формулы по каждой теме
Решай новые задачи каждый день
Вдумчиво разбирай решения
ШКОЛКОВО.
Готовиться с нами - ЛЕГКО!
Подтемы раздела обработка целочисленной информации
Решаем задачу:

Ошибка.
Попробуйте повторить позже

Задача 1#27869

Напишите программу, которая ищет среди целых чисел, принадлежащих числовому отрезку [300000; 333000], числа, имеющие ровно 3 различных натуральных делителя. Запишите такие числа через пробел, в порядке возрастания.

Показать ответ и решение
def divs(n): # функция возращающая список делителей числа
    d = set()
    for j in range(1, int(n ** 0.5) + 1):
        if n % j == 0:
            d.add(j)
            d.add(n//j)
        if len(d) > 3: # для оптимизации выходим из функции если кол-во делителей больше 3
            return d
    return sorted(d)


for i in range(300000, 333000 + 1):
    if len(divs(i)) == 3:
        print(i)

Ответ: 310249 316969 323761 326041 332929

Специальные программы

Все специальные программы

Программа
лояльности v2.0

Приглашай друзей в Школково и получай вознаграждение до 10%!

Крути рулетку
и выигрывай призы!

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

Бесплатное онлайн-обучение

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

Налоговые вычеты

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

Специальное предложение
для учителей

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

Вернём деньги за курс
за твою сотку на ЕГЭ

Сдать экзамен на сотку и получить обратно деньги за подготовку теперь вполне реально!

cyberpunkMouse
cyberpunkMouse
Рулетка
Вы можете получить скидку в рулетке!