Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
梦境迷离
Cs Summary Reflection
提交
86008616
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,发现更多精彩内容 >>
提交
86008616
编写于
4月 22, 2020
作者:
梦境迷离
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
rust leetcode interview 32-2
上级
cf1be800
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
100 addition
and
0 deletion
+100
-0
rust-leetcode/README.md
rust-leetcode/README.md
+40
-0
rust-leetcode/src/Solution.rs
rust-leetcode/src/Solution.rs
+60
-0
未找到文件。
rust-leetcode/README.md
浏览文件 @
86008616
...
...
@@ -1180,4 +1180,44 @@ impl Solution {
start
}
}
```
*
面试题32 - II. 从上到下打印二叉树 II
```
rust
impl
Solution
{
//leetcode 102
pub
fn
level_order
(
root
:
Option
<
Rc
<
RefCell
<
TreeNode
>>>
)
->
Vec
<
Vec
<
i32
>>
{
let
mut
ret
=
Vec
::
new
();
let
mut
nodes
=
VecDeque
::
new
();
let
mut
row
=
Vec
::
new
();
let
mut
flag
=
root
.clone
();
nodes
.push_back
(
root
.clone
());
while
!
nodes
.is_empty
()
{
let
tmp
=
nodes
.pop_front
();
if
let
Some
(
node
)
=
tmp
{
if
let
Some
(
n
)
=
node
{
row
.push
(
n
.try_borrow
()
.unwrap
()
.val
);
if
n
.try_borrow
()
.unwrap
()
.left
.is_some
()
{
nodes
.push_back
(
n
.try_borrow
()
.unwrap
()
.left
.clone
());
}
if
n
.try_borrow
()
.unwrap
()
.right
.is_some
()
{
nodes
.push_back
(
n
.try_borrow
()
.unwrap
()
.right
.clone
());
}
if
let
Some
(
f
)
=
flag
.borrow
()
{
if
f
.as_ptr
()
==
n
.as_ptr
()
{
//直接back导致as_ptr不等
let
tail
=
nodes
.pop_back
();
if
tail
.is_some
()
{
flag
=
tail
.clone
()
.unwrap
();
nodes
.push_back
(
tail
.unwrap
());
}
ret
.push
(
row
);
row
=
Vec
::
new
();
}
}
}
}
}
ret
}
}
```
\ No newline at end of file
rust-leetcode/src/Solution.rs
浏览文件 @
86008616
...
...
@@ -1600,6 +1600,65 @@ fn leetcode_1413() {
println!
(
"{}"
,
ret
)
}
///从上到下打印二叉树 II
fn
interview_32_2
()
{
println!
(
"interview_32_2"
);
use
std
::
rc
::
Rc
;
use
std
::
cell
::
RefCell
;
impl
Solution
{
//leetcode 102
pub
fn
level_order
(
root
:
Option
<
Rc
<
RefCell
<
TreeNode
>>>
)
->
Vec
<
Vec
<
i32
>>
{
let
mut
ret
=
Vec
::
new
();
let
mut
nodes
=
VecDeque
::
new
();
let
mut
row
=
Vec
::
new
();
let
mut
flag
=
root
.clone
();
nodes
.push_back
(
root
.clone
());
while
!
nodes
.is_empty
()
{
let
tmp
=
nodes
.pop_front
();
if
let
Some
(
node
)
=
tmp
{
if
let
Some
(
n
)
=
node
{
row
.push
(
n
.try_borrow
()
.unwrap
()
.val
);
if
n
.try_borrow
()
.unwrap
()
.left
.is_some
()
{
nodes
.push_back
(
n
.try_borrow
()
.unwrap
()
.left
.clone
());
}
if
n
.try_borrow
()
.unwrap
()
.right
.is_some
()
{
nodes
.push_back
(
n
.try_borrow
()
.unwrap
()
.right
.clone
());
}
if
let
Some
(
f
)
=
flag
.borrow
()
{
if
f
.as_ptr
()
==
n
.as_ptr
()
{
//直接back导致as_ptr不等
let
tail
=
nodes
.pop_back
();
if
tail
.is_some
()
{
flag
=
tail
.clone
()
.unwrap
();
nodes
.push_back
(
tail
.unwrap
());
}
ret
.push
(
row
);
row
=
Vec
::
new
();
}
}
}
}
}
ret
}
}
let
e7
=
Some
(
Rc
::
new
(
RefCell
::
new
(
TreeNode
{
val
:
7
,
left
:
None
,
right
:
None
})));
let
e15
=
Some
(
Rc
::
new
(
RefCell
::
new
(
TreeNode
{
val
:
15
,
left
:
None
,
right
:
None
})));
let
e20
=
Some
(
Rc
::
new
(
RefCell
::
new
(
TreeNode
{
val
:
20
,
left
:
e15
,
right
:
e7
})));
let
e9
=
Some
(
Rc
::
new
(
RefCell
::
new
(
TreeNode
{
val
:
9
,
left
:
None
,
right
:
None
})));
let
e3
=
Some
(
Rc
::
new
(
RefCell
::
new
(
TreeNode
{
val
:
3
,
left
:
e9
,
right
:
e20
})));
// let e2 = Some(Rc::new(RefCell::new(TreeNode { val: 2, left: None, right: None })));
// let e1 = Some(Rc::new(RefCell::new(TreeNode { val: 1, left: e2, right: None })));
let
ret
=
Solution
::
level_order
(
e3
);
for
v
in
ret
.iter
()
{
for
c
in
v
.iter
()
{
print!
(
"{}"
,
c
)
}
println!
(
"
\n
"
)
}
}
///所有方法调用
pub
fn
solutions
()
{
interview_58_2
();
...
...
@@ -1651,6 +1710,7 @@ pub fn solutions() {
leetcode_292
();
leetcode_1160
();
leetcode_1413
();
interview_32_2
();
}
fn
print_vec
(
nums
:
Vec
<
i32
>
)
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录