【LeetCode(Java) - 254】因子的組合
1、題目描述
2、解題思路
題目要求因子的範圍是 [2, n-1]。
先對 n 開平方根取整數得到 sqrtN,那麼,n 的因子中,一半因子小於等於 sqrtN,一半因子大於等於 sqrtN。
於是我們只需要從 [2, sqrtN] 中找到一個因數 i,則另一個因數就是 n/i,即找到了一對因數。
題意要返回所有的因子組合,於是我們可以對兩個因子進行遞迴拆分,最後合併。
以 n == 16 為例:
n 開平方根為 4,於是先從 [2, 4] 區間找因子,只要能整除 16,就是因子,於是找到了 2 和 4。
當一個因子為 2 時,另一個因子為 16/2 = 8;
當一個因子為 4 時,另一個因子為 16/4 = 4;
於是找到了因子組合:{2,8}、{4,4}。
每確定一個因子組合,都對第二個數字進行拆分,比如 {2,8} 需要對 8 進行拆分,8 的因子不能小於和它配對的 2。
於是問題又變成:找數字 8 的區間在 [2, 7] 的因子,按照一樣的遞迴計算。
8 的因子組合為 {4,2}、{2,2,2}。
給 8 的因子組合都舔加一個它的搭檔,這裡是 2,就是 16 的因子組合了:
{4,2,2}、{2,2,2,2}
所以 16 的因子組合為:{2,8}、{2,4,2,2}、{2,2,2,2}
對於 {4,4} 同理,對第二個 4 進行拆分,4 的因子不能小於和它配對的 4,發現沒有小於 4 的因數。
綜合,16 的因子組合為 {2,8}、{2,4,2,2}、{2,2,2,2}、{4,4}
3、解題程式碼
class Solution {
public List<List<Integer>> getFactors(int n) {
return dfs(2, n);
}
/**
* 大於等於 start 的 num 的因子組合
* @param start
* @param num
* @return
*/
public static List<List<Integer>> dfs(int start, int num) {
if (num == 1) {
return new ArrayList<>();
}
// C = A × B,則 A 和 B 一個小於等於根號 C,一個大於等於根號 C
int qNum = (int) Math.sqrt(num);
List<List<Integer>> result = new ArrayList<>();
// 找出 [start, 根號num] 中,是 num 因子的數字
for (int i = start; i <= qNum; i++) {
if (num % i == 0) { // 找到一個因子
List<Integer> simpleList = new ArrayList<>();
simpleList.add(i); // 小於或等於根號 num 的因子
simpleList.add(num / i); // 大於或等於根號 num 的因子
result.add(simpleList); // 找到一對因子
// 檢查大於等於根號 num 的因子能怎麼拆
List<List<Integer>> nextLists = dfs(i, num / i);
for (List<Integer> list : nextLists) {
list.add(i); // list 的元素相乘是 num/i ,舔一個 i,相乘就是 num
result.add(list);
}
}
}
return result;
}
}
相關文章
- leetcode:組合總和II(回溯java)LeetCodeJava
- LeetCode-077-組合LeetCode
- 基於Barra多因子模型的組合權重優化模型優化
- 基於Barra多因子模型的組合權重最佳化模型
- 【刷題1】LeetCode 39. 組合總和 java基礎LeetCodeJava
- LeetCode39. 組合總和LeetCode
- LeetCode-175:組合兩個表LeetCode
- LeetCode216.組合總和lllLeetCode
- LeetCode40.組合總和IILeetCode
- LeetCode-040-組合總和 IILeetCode
- LeetCode題目:39. 組合總和 解題思路及Java實現LeetCodeJava
- 【Java】繼承、抽象、組合Java繼承抽象
- Java基礎06 組合Java
- leetcode日記17. 電話號碼的字母組合LeetCode
- 【leetcode】22. Generate Parentheses 合法括號串的所有組合LeetCode
- leetcode 面試題08.08. 有重複字串的排列組合LeetCode面試題字串
- Java 組合模式及其應用Java模式
- LeetCode 39. 組合總和 40.組合總和II 131.分割回文串LeetCode
- leetcode 617.合併二叉樹 JavaLeetCode二叉樹Java
- R語言中使用線性模型、迴歸決策樹自動組合特徵因子水平R語言模型特徵
- 《JAVA併發程式設計實戰》物件的組合Java程式設計物件
- Java設計模式之(十)——組合模式Java設計模式
- 集合的組合
- 世界衛生組織:2021年世界聽力報告(254頁)
- Java HashMap中的載入因子及初始容量深入分析JavaHashMap
- 程式碼隨想錄演算法訓練營第二十三天| leetcode39. 組合總和、leetcode40.組合總和II、leetcode131.分割回文串演算法LeetCode
- 【力扣】組合總和3(組合的去重)力扣
- mysql的組合索引MySql索引
- 組合
- java23種設計模式——八、組合模式Java設計模式
- Java高效開發-SSH+Wireshark+tcpdump組合拳JavaTCP
- 【數學】組合數學 - 排列組合
- 圖解Leetcode組合總和系列——回溯(剪枝優化)+動態規劃圖解LeetCode優化動態規劃
- 組合數的逆元求法
- Python_類的組合Python
- 組合數學筆記-排列與組合筆記
- 組合模式-統一的處理個別物件與組合物件模式物件
- 組合模式模式