Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
梦境迷离
Cs Summary Reflection
提交
4247a05a
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,发现更多精彩内容 >>
提交
4247a05a
编写于
3月 21, 2020
作者:
梦境迷离
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
rust leetcode
上级
32dabe35
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
112 addition
and
11 deletion
+112
-11
rust-leetcode/README.md
rust-leetcode/README.md
+58
-10
rust-leetcode/src/Solution.rs
rust-leetcode/src/Solution.rs
+54
-1
未找到文件。
rust-leetcode/README.md
浏览文件 @
4247a05a
...
...
@@ -304,17 +304,65 @@ impl Solution {
*
从尾到头打印链表
```
rust
impl
Solution
{
pub
fn
reverse_print
(
head
:
Option
<
Box
<
ListNode
>>
)
->
Vec
<
i32
>
{
let
mut
ret
=
Vec
::
<
i32
>
::
new
();
let
mut
node
=
head
.as_ref
();
loop
{
if
let
Some
(
root
)
=
node
{
ret
.push
(
root
.val
);
node
=
root
.next
.as_ref
();
}
else
{
break
}
pub
fn
reverse_print
(
head
:
Option
<
Box
<
ListNode
>>
)
->
Vec
<
i32
>
{
let
mut
ret
=
Vec
::
<
i32
>
::
new
();
let
mut
node
=
head
.as_ref
();
loop
{
if
let
Some
(
root
)
=
node
{
ret
.push
(
root
.val
);
node
=
root
.next
.as_ref
();
}
else
{
break
}
}
ret
.reverse
();
ret
}
}
```
*
二叉搜索树的范围和
```
rust
impl
Solution
{
pub
fn
range_sum_bst
(
root
:
Option
<
Rc
<
RefCell
<
TreeNode
>>>
,
l
:
i32
,
r
:
i32
)
->
i32
{
let
mut
ret
=
0
;
let
mut
nodes
=
VecDeque
::
new
();
nodes
.push_back
(
root
);
while
!
nodes
.is_empty
()
{
let
tmp
=
nodes
.pop_back
();
if
let
Some
(
node
)
=
tmp
{
if
let
Some
(
n
)
=
node
{
if
n
.try_borrow
()
.unwrap
()
.val
>=
l
&&
n
.try_borrow
()
.unwrap
()
.val
<=
r
{
ret
+=
n
.try_borrow
()
.unwrap
()
.val
}
//满足条件继续查找
if
n
.try_borrow
()
.unwrap
()
.val
>
l
{
nodes
.push_back
(
n
.try_borrow
()
.unwrap
()
.left
.clone
());
}
if
n
.try_borrow
()
.unwrap
()
.val
<
r
{
nodes
.push_back
(
n
.try_borrow
()
.unwrap
()
.right
.clone
());
}
}
}
ret
.reverse
();
ret
}
ret
}
pub
fn
range_sum_bst2
(
root
:
Option
<
Rc
<
RefCell
<
TreeNode
>>>
,
l
:
i32
,
r
:
i32
)
->
i32
{
let
mut
ret
=
0
;
fn
bst
(
root
:
Option
<
Rc
<
RefCell
<
TreeNode
>>>
,
l
:
i32
,
r
:
i32
,
ret
:
&
mut
i32
)
{
if
let
Some
(
node
)
=
root
{
if
node
.try_borrow
()
.unwrap
()
.val
>=
l
&&
node
.try_borrow
()
.unwrap
()
.val
<=
r
{
*
ret
+=
node
.try_borrow
()
.unwrap
()
.val
}
if
node
.try_borrow
()
.unwrap
()
.val
>
l
{
bst
(
node
.try_borrow
()
.unwrap
()
.left
.clone
(),
l
,
r
,
ret
)
}
if
node
.try_borrow
()
.unwrap
()
.val
<
r
{
bst
(
node
.try_borrow
()
.unwrap
()
.right
.clone
(),
l
,
r
,
ret
)
}
}
}
//可变借用,修改外函数的变量ret
bst
(
root
,
l
,
r
,
&
mut
ret
);
ret
}
}
```
rust-leetcode/src/Solution.rs
浏览文件 @
4247a05a
...
...
@@ -488,7 +488,7 @@ fn interview_06() {
if
let
Some
(
root
)
=
node
{
ret
.push
(
root
.val
);
node
=
root
.next
.as_ref
();
}
else
{
break
}
}
else
{
break
;
}
}
ret
.reverse
();
ret
...
...
@@ -501,6 +501,58 @@ fn interview_06() {
println!
(
"{:?}"
,
ret
);
}
///二叉搜索树的范围和
fn
leetcode_938
()
{
println!
(
"leetcode_938"
);
use
std
::
rc
::
Rc
;
use
std
::
cell
::
RefCell
;
impl
Solution
{
pub
fn
range_sum_bst
(
root
:
Option
<
Rc
<
RefCell
<
TreeNode
>>>
,
l
:
i32
,
r
:
i32
)
->
i32
{
let
mut
ret
=
0
;
let
mut
nodes
=
VecDeque
::
new
();
nodes
.push_back
(
root
);
while
!
nodes
.is_empty
()
{
let
tmp
=
nodes
.pop_back
();
if
let
Some
(
node
)
=
tmp
{
if
let
Some
(
n
)
=
node
{
if
n
.try_borrow
()
.unwrap
()
.val
>=
l
&&
n
.try_borrow
()
.unwrap
()
.val
<=
r
{
ret
+=
n
.try_borrow
()
.unwrap
()
.val
}
//满足条件继续查找
if
n
.try_borrow
()
.unwrap
()
.val
>
l
{
nodes
.push_back
(
n
.try_borrow
()
.unwrap
()
.left
.clone
());
}
if
n
.try_borrow
()
.unwrap
()
.val
<
r
{
nodes
.push_back
(
n
.try_borrow
()
.unwrap
()
.right
.clone
());
}
}
}
}
ret
}
pub
fn
range_sum_bst2
(
root
:
Option
<
Rc
<
RefCell
<
TreeNode
>>>
,
l
:
i32
,
r
:
i32
)
->
i32
{
let
mut
ret
=
0
;
fn
bst
(
root
:
Option
<
Rc
<
RefCell
<
TreeNode
>>>
,
l
:
i32
,
r
:
i32
,
ret
:
&
mut
i32
)
{
if
let
Some
(
node
)
=
root
{
if
node
.try_borrow
()
.unwrap
()
.val
>=
l
&&
node
.try_borrow
()
.unwrap
()
.val
<=
r
{
*
ret
+=
node
.try_borrow
()
.unwrap
()
.val
}
if
node
.try_borrow
()
.unwrap
()
.val
>
l
{
bst
(
node
.try_borrow
()
.unwrap
()
.left
.clone
(),
l
,
r
,
ret
)
}
if
node
.try_borrow
()
.unwrap
()
.val
<
r
{
bst
(
node
.try_borrow
()
.unwrap
()
.right
.clone
(),
l
,
r
,
ret
)
}
}
}
//可变借用,修改外函数的变量ret
bst
(
root
,
l
,
r
,
&
mut
ret
);
ret
}
}
}
///所有方法调用
pub
fn
solutions
()
{
interview_58_2
();
...
...
@@ -518,6 +570,7 @@ pub fn solutions() {
interview_05
();
leetcode_1221
();
interview_06
();
leetcode_938
();
}
fn
print_vec
(
nums
:
Vec
<
i32
>
)
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录