Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
梦境迷离
Cs Summary Reflection
提交
d43f7f7e
C
Cs Summary Reflection
项目概览
梦境迷离
/
Cs Summary Reflection
12 个月 前同步成功
通知
4
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
C
Cs Summary Reflection
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
d43f7f7e
编写于
5月 26, 2020
作者:
梦境迷离
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
leetcode 0801
上级
822c84cb
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
77 addition
and
1 deletion
+77
-1
rust-leetcode/README.md
rust-leetcode/README.md
+2
-1
rust-leetcode/src/interview_08_01.rs
rust-leetcode/src/interview_08_01.rs
+74
-0
rust-leetcode/src/main.rs
rust-leetcode/src/main.rs
+1
-0
未找到文件。
rust-leetcode/README.md
浏览文件 @
d43f7f7e
...
...
@@ -85,4 +85,5 @@ Leetcode Rust 实现
*
[
面试题10- I 斐波那契数列
](
src/interview_10_01.rs
)
*
[
633 平方数之和
](
src/leetcode_633.rs
)
*
[
204 计数质数
](
src/leetcode_204.rs
)
*
[
686 重复叠加字符串匹配
](
src/leetcode_686.rs
)
\ No newline at end of file
*
[
686 重复叠加字符串匹配
](
src/leetcode_686.rs
)
*
[
面试题 08.01 三步问题
](
src/interview_08_01.rs
)
\ No newline at end of file
rust-leetcode/src/interview_08_01.rs
浏览文件 @
d43f7f7e
use
crate
::
pre_structs
::
Solution
;
/// 面试题 08.01. 三步问题
/// 三步问题。有个小孩正在上楼梯,楼梯有n阶台阶,小孩一次可以上1阶、2阶或3阶。实现一种方法,计算小孩有多少种上楼梯的方式。结果可能很大,你需要对结果模1000000007。
impl
Solution
{
//对于最后一步有三种可能,相加即可F(n-1)+F(n-2)+F(n-3)
//递归 n=61超时
pub
fn
ways_to_step
(
n
:
i32
)
->
i32
{
if
n
==
1
{
return
1
;
}
if
n
==
2
{
return
2
;
}
if
n
==
3
{
return
4
;
}
return
{
let
mut
ret
=
Solution
::
ways_to_step
(
n
-
1
)
+
Solution
::
ways_to_step
(
n
-
2
)
+
Solution
::
ways_to_step
(
n
-
3
);
if
ret
>
1000000007
{
ret
-=
1000000007
;
}
else
{
ret
;
}
ret
};
}
//8MS 80%,9.1MB 100%
pub
fn
ways_to_step_
(
n
:
i32
)
->
i32
{
if
n
==
1
{
return
1
;
}
if
n
==
2
{
return
2
;
}
if
n
==
3
{
return
4
;
}
let
mut
dp
=
vec!
[
0i64
;
(
n
+
1
)
as
usize
];
dp
[
1
]
=
1
;
dp
[
2
]
=
2
;
dp
[
3
]
=
4
;
for
i
in
4u
size
..=
n
as
usize
{
let
mut
t
=
dp
[
i
-
1
]
+
dp
[
i
-
2
]
+
dp
[
i
-
3
];
if
t
>
1000000007
{
t
%=
1000000007
;
}
else
{
t
;
}
dp
[
i
]
=
t
;
}
(
dp
[
n
as
usize
])
as
i32
}
}
#[cfg(test)]
mod
test
{
use
crate
::
pre_structs
::
Solution
;
#[test]
fn
ways_to_step
()
{
let
ret
=
Solution
::
ways_to_step
(
5
);
println!
(
"{}"
,
ret
);
let
ret2
=
Solution
::
ways_to_step_
(
61
);
println!
(
"{}"
,
ret2
);
let
ret3
=
Solution
::
ways_to_step_
(
5
);
assert_eq!
(
ret
,
13
);
assert_eq!
(
ret2
,
752119970
);
assert_eq!
(
ret3
,
13
);
}
}
rust-leetcode/src/main.rs
浏览文件 @
d43f7f7e
...
...
@@ -6,6 +6,7 @@ pub mod interview_03_04;
pub
mod
interview_04_02
;
pub
mod
interview_05
;
pub
mod
interview_06
;
pub
mod
interview_08_01
;
pub
mod
interview_09
;
pub
mod
interview_10_01
;
pub
mod
interview_16_07
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录