Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenDocCN
awesome-algorithm
提交
8479e6b8
A
awesome-algorithm
项目概览
OpenDocCN
/
awesome-algorithm
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
A
awesome-algorithm
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
未验证
提交
8479e6b8
编写于
9月 19, 2018
作者:
K
Keqi Huang
提交者:
GitHub
9月 19, 2018
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Create 254._Factor_Combinations.md
上级
c3ba6a4f
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
113 addition
and
0 deletion
+113
-0
docs/Leetcode_Solutions/254._Factor_Combinations.md
docs/Leetcode_Solutions/254._Factor_Combinations.md
+113
-0
未找到文件。
docs/Leetcode_Solutions/254._Factor_Combinations.md
0 → 100644
浏览文件 @
8479e6b8
# 254. Factor Combinations
**<font color=red>难度: Medium</font>**
## 刷题内容
> 原题连接
*
https://leetcode.com/problems/factor-combinations/description/
> 内容描述
```
Numbers can be regarded as product of its factors. For example,
8 = 2 x 2 x 2;
= 2 x 4.
Write a function that takes an integer n and return all possible combinations of its factors.
Note:
You may assume that n is always positive.
Factors should be greater than 1 and less than n.
Example 1:
Input: 1
Output: []
Example 2:
Input: 37
Output:[]
Example 3:
Input: 12
Output:
[
[2, 6],
[2, 2, 3],
[3, 4]
]
Example 4:
Input: 32
Output:
[
[2, 16],
[2, 2, 8],
[2, 2, 2, 4],
[2, 2, 2, 2, 2],
[2, 4, 4],
[4, 8]
]
```
## 解题方案
> 思路 1
******- 时间复杂度: O(N)******
- 空间复杂度: O(N)
****
**
就每次遍历到sqrt(n)就够了,再往后面过去其实重复了, beats 62.6%
```
python
class
Solution
(
object
):
def
getFactors
(
self
,
n
):
"""
:type n: int
:rtype: List[List[int]]
"""
from
math
import
sqrt
if
n
<
4
:
return
[]
res
=
[]
for
i
in
range
(
2
,
int
(
sqrt
(
n
))
+
1
):
if
n
%
i
==
0
and
i
<=
n
/
i
:
res
.
append
([
i
]
+
[
n
/
i
])
for
j
in
self
.
getFactors
(
n
/
i
):
if
j
and
i
<=
j
[
0
]:
res
.
append
([
i
]
+
j
)
return
res
```
> 思路 1
******- 时间复杂度: O(N)******
- 空间复杂度: O(N)
****
**
想着用一下memorization会更快一点,果然beats 100%
```
python
class
Solution
(
object
):
cache
=
{}
def
getFactors
(
self
,
n
):
"""
:type n: int
:rtype: List[List[int]]
"""
from
math
import
sqrt
if
n
<
4
:
return
[]
if
n
in
self
.
cache
:
return
self
.
cache
[
n
]
else
:
res
=
[]
for
i
in
range
(
2
,
int
(
sqrt
(
n
))
+
1
):
if
n
%
i
==
0
and
i
<=
n
/
i
:
res
.
append
([
i
]
+
[
n
/
i
])
for
j
in
self
.
getFactors
(
n
/
i
):
if
j
and
i
<=
j
[
0
]:
res
.
append
([
i
]
+
j
)
self
.
cache
[
n
]
=
res
return
res
```
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录