Форум программистов, компьютерный форум, киберфорум
Python: Решение задач
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.69/29: Рейтинг темы: голосов - 29, средняя оценка - 4.69
1 / 1 / 0
Регистрация: 22.01.2023
Сообщений: 2

Разложение на множители

22.01.2023, 02:39. Показов 6271. Ответов 6

Студворк — интернет-сервис помощи студентам
Факторизацией называется разложение произвольного натурального числа n в произведение целых положительных чисел, больших 1. Два разложения числа n, которые отличались лишь порядком сомножителей, будем считать одинаковыми. Например, число 12 имеет четыре различные факторизации: 12, 6⋅2, 4⋅3 и 3⋅2⋅2. Так как всех факторизаций может быть много, будем выделять такие, у которых наибольший множитель не превосходит заданного числа m.

Вам необходимо подсчитать количество факторизаций данного числа n с наибольшим множителем, не превосходящим m.

Формат входных данных
В единственной строке записаны два целых числа n и m (1<n≤1011,,1<m≤n).

Формат выходных данных
Выведите одно целое число — искомое количество факторизаций.

Система оценивания
Баллы за каждый тест начисляются независимо.
Ввод
4 2
Вывод
1
Ввод
12 12
Вывод
4
Ввод
11 20
Вывод
0
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
22.01.2023, 02:39
Ответы с готовыми решениями:

Разложение на простые множители (сириус)
Не могу решить казалось бы простую задачу, помогите пожалуйста с решением. (знаю что такая тема была на форуме, но от туда ничего не...

Разложение на множители
Добрый день. Нужно разложить число на множители в виде: 24=2*2*2*2*3. Но в программе получается результат: 24=2*2*2*3. Не знаю, откуда...

Разложение на множители
Задача разложения числа на простые(!) множители решается многими методами и довольно быстро. Существует ли встроенная функция или метод...

6
Йуный плагиат-падаван)
176 / 119 / 45
Регистрация: 17.10.2022
Сообщений: 566
22.01.2023, 11:15
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
def factorization_count(n, m):
    def prime_factorization(n):
        factors = []
        d = 2
        while d * d <= n:
            while (n % d) == 0:
                factors.append(d)
                n //= d
            d += 1
        if n > 1:
            factors.append(n)
        return factors
 
    n_factors = prime_factorization(n)
    m_factors = prime_factorization(m)
 
    count = 1
    for factor in set(n_factors):
        if factor in m_factors:
            count *= n_factors.count(factor) + 1
        else:
            count *= n_factors.count(factor) + 1
 
    return count
 
print(factorization_count(4, 2)) # 1
print(factorization_count(12, 12)) # 4
print(factorization_count(11, 20)) # 0
0
Эксперт Python
 Аватар для Red white socks
4523 / 1899 / 336
Регистрация: 18.01.2021
Сообщений: 3,489
22.01.2023, 12:20
Цитата Сообщение от DOPIXKMNLD Посмотреть сообщение
Python
1
2
3
4
        if factor in m_factors:
            count *= n_factors.count(factor) + 1
        else:
            count *= n_factors.count(factor) + 1
1
Status 418
Эксперт Python
4584 / 2350 / 601
Регистрация: 26.11.2017
Сообщений: 5,262
Записей в блоге: 3
22.01.2023, 12:22
задача решается за https://www.cyberforum.ru/cgi-bin/latex.cgi?O(\sqrt{n})
1
 Аватар для rim41
1045 / 313 / 78
Регистрация: 16.03.2020
Сообщений: 954
22.01.2023, 12:23

Не по теме:

Red white socks, Это побочный эффект от отсутствия комментариев

2
Йуный плагиат-падаван)
176 / 119 / 45
Регистрация: 17.10.2022
Сообщений: 566
22.01.2023, 17:05
Red white socks, это троль
0
Эксперт Python
8840 / 4492 / 1864
Регистрация: 27.03.2020
Сообщений: 7,312
22.01.2023, 17:18
DOPIXKMNLD, число “m” по условию задачи не нужно раскладывать на множители - оно для сравнения с множителями числа “n”…
… данного числа n с наибольшим множителем, не превосходящим m.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
22.01.2023, 17:18
Помогаю со студенческими работами здесь

Разложение на простые множители
Требуется разложить целое число N на простые множители и вывести результат в порядке возрастания множителей с указанием степени. ...

Разложение на простые множители
Разложение на простые множители Требуется разложить целое число N на простые множители с учётом их степени и вывести результат в порядке...

Разложение на простые множители
Разложение на простые Требуется разложить целое число N на простые множители с учётом их степени и вывести результат в порядке...

Разложение на простые множители (Время: 1 сек. Память: 16 Мб Сложность: 27%)
Требуется вывести представление целого числа N в виде произведения простых чисел. Входные данные Входной файл INPUT.TXT содержит...

Разложение на множители
Любое число может быть единственным образом разложено на простые сомножители. Написать программу для выполнения такого разложения.


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка. Рецензия / Мнение Это мой обзор планшета X220 с точки зрения школьника. Недавно я решила попытаться уменьшить свой. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru