天天看點

LeetCode 1808. 好因子的最大數目(整數拆分,乘積最大)

文章目錄

    • 1. 題目
    • 2. 解題

1. 題目

給你一個正整數 primeFactors 。你需要構造一個正整數 n ,它滿足以下條件:

  • n 質因數(質因數需要考慮重複的情況)的數目 不超過 primeFactors 個。
  • n 好因子的數目 最大化。

    如果 n 的一個因子可以被 n 的每一個質因數整除,我們稱這個因子是 好因子 。

    比方說,如果 n = 12 ,那麼它的質因數為 [2,2,3] ,那麼 6 和 12 是好因子,但 3 和 4 不是。

請你傳回 n 的好因子的數目。

由于答案可能會很大,請傳回答案對 10^9 + 7 取餘 的結果。

請注意,一個質數的定義是大于 1 ,且不能被分解為兩個小于該數的自然數相乘。一個數 n 的質因子是将 n 分解為若幹個質因子,且它們的乘積為 n 。

示例 1:
輸入:primeFactors = 5
輸出:6
解釋:200 是一個可行的 n 。
它有 5 個質因子:[2,2,2,5,5] ,且有 6 個好因子:[10,20,40,50,100,200] 。
不存在别的 n 有至多 5 個質因子,且同時有更多的好因子。

示例 2:
輸入:primeFactors = 8
輸出:18
 
提示:
1 <= primeFactors <= 10^9           

複制

來源:力扣(LeetCode)

連結:https://leetcode-cn.com/problems/maximize-number-of-nice-divisors

著作權歸領扣網絡所有。商業轉載請聯系官方授權,非商業轉載請注明出處。

2. 解題

  • 一個數有 primeFactors 個質因子
  • 不同的質因子個數 n1,n2,…,nk, 這 k 個數的和為 primeFactors,且 k 個數的乘積最大(好因子數目最大)
  • 參考 LeetCode 343. 整數拆分(DP),分成盡可能多的 3,不夠的用 2
  • 外加快速幂,求 3 的大數次幂
class Solution {
    int mod = 1e9+7;
public:
    int maxNiceDivisors(int primeFactors) {
        if(primeFactors <= 3)
            return primeFactors;
        if(primeFactors%3 == 0)
            return mypow(3, primeFactors/3);
        else if(primeFactors%3 == 1)
            return mypow(3, primeFactors/3-1)*4LL%mod;
        else
            return mypow(3, primeFactors/3)*2LL%mod;
    }
    int mypow(int base, int n)
    {
        long long ans = 1, p = base;
        while(n)
        {
            if(n&1)
                ans = (ans*p)%mod;
            p = (p*p)%mod;
            n >>= 1;
        }
        return ans;
    }
};           

複制

0 ms 5.8 MB C++

我的CSDN部落格位址 https://michael.blog.csdn.net/

長按或掃碼關注我的公衆号(Michael阿明),一起加油、一起學習進步!