因式分解
https://www.lintcode.com/problem/652/?utm_source=sc-cheatsheet-cyc
描述
一个非负数可以被视为其因数的乘积。编写一个函数来返回整数 n 的因数所有可能组合。
组合中的元素(a1,a2,...,ak)必须是非降序。(即,a1≤a2≤...≤ak)。
结果集中不能包含重复的组合。
样例
样例1
样例2
解题思路
算法:DFS
从2
到sqrt(n)
枚举因子,若存在一个数是n
的因子,则继续从这个数到sqrt(n)
枚举因子
从
2
开始搜,若当前数是n
的因子,则加入当前因子队列继续搜下一个大于当前因子的因子
当前组合搜完继续由下一个更大的因子开始搜
复杂度分析
时间复杂度
O(nlog(n))
dfs搜索
空间复杂度
O(n)
记录所有因子组合
Last updated