Этот интересный вопрос гораздо сложнее, чем кажется, и на него не было ответа. Вопрос можно разделить на 2 очень разных вопроса.
1 дано N, найдите список L из простых факторов N
2 с учетом L, рассчитать количество уникальных комбинаций
Все ответы, которые я вижу до сих пор, относятся к № 1, и я не могу упомянуть, что он не поддается огромным количествам. Для N среднего размера, даже для 64-битных чисел, это легко; для огромного N проблема факторинга может быть «навсегда». От этого зависит шифрование с открытым ключом.
Вопрос № 2 требует дальнейшего обсуждения. Если L содержит только уникальные числа, это простой расчет с использованием формулы комбинации для выбора k объектов из n элементов. На самом деле, вам нужно суммировать результаты применения формулы при изменении k от 1 до sizeof (L). Однако L обычно будет содержать несколько вхождений нескольких простых чисел. Например, L = {2,2,2,3,3,5} является факторизацией N = 360. Теперь эта проблема довольно сложная!
Возвращаясь к # 2, для данной коллекции C, содержащей k элементов, такой, что у элемента a есть дубликаты, а у элемента b дубликаты b и т. Д. Сколько существует уникальных комбинаций от 1 до k-1 элементов? Например, {2}, {2,2}, {2,2,2}, {2,3}, {2,2,3,3} должны появляться каждый раз и только один раз, если L = {2,2 , 2,3,3,5}. Каждая такая уникальная подколлекция является уникальным делителем N путем умножения элементов в подколлекции.