Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
梦境迷离
Cs Summary Reflection
提交
93a7b038
C
Cs Summary Reflection
项目概览
梦境迷离
/
Cs Summary Reflection
大约 1 年 前同步成功
通知
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,发现更多精彩内容 >>
提交
93a7b038
编写于
5月 24, 2020
作者:
梦境迷离
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
rust leetcode 101
上级
0c6ae412
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
64 addition
and
0 deletion
+64
-0
rust-leetcode/README.md
rust-leetcode/README.md
+1
-0
rust-leetcode/src/leetcode_101.rs
rust-leetcode/src/leetcode_101.rs
+62
-0
rust-leetcode/src/main.rs
rust-leetcode/src/main.rs
+1
-0
未找到文件。
rust-leetcode/README.md
浏览文件 @
93a7b038
...
...
@@ -16,6 +16,7 @@ Leetcode Rust 实现
*
[
面试题 54 二叉搜索树的第k大节点
](
src/interview_54.rs
)
*
[
面试题 32 - II. 从上到下打印二叉树 II
](
src/interview_32_2.rs
)
*
[
100 相同的树
](
src/leetcode_100.rs
)
*
[
101 对称二叉树
](
src/leetcode_101.rs
)
## 链表&栈&队列
...
...
rust-leetcode/src/leetcode_101.rs
0 → 100644
浏览文件 @
93a7b038
use
std
::
borrow
::
Borrow
;
use
std
::
cell
::
RefCell
;
use
std
::
rc
::
Rc
;
use
crate
::
pre_structs
::{
Solution
,
TreeNode
};
///101. 对称二叉树
impl
Solution
{
///unsafe一把梭
pub
fn
is_symmetric
(
root
:
Option
<
Rc
<
RefCell
<
TreeNode
>>>
)
->
bool
{
fn
is_mirror
(
left
:
&
Option
<
Rc
<
RefCell
<
TreeNode
>>>
,
right
:
&
Option
<
Rc
<
RefCell
<
TreeNode
>>>
,
)
->
bool
{
match
(
left
.borrow
(),
right
.borrow
())
{
(
Some
(
l
),
Some
(
r
))
=>
unsafe
{
if
(
*
l
.as_ptr
())
.val
==
(
*
r
.as_ptr
())
.val
{
is_mirror
(
&
(
*
l
.as_ptr
())
.left
,
&
(
*
r
.as_ptr
())
.right
)
&&
is_mirror
(
&
(
*
l
.as_ptr
())
.right
,
&
(
*
r
.as_ptr
())
.left
)
}
else
{
false
}
},
(
None
,
None
)
=>
true
,
(
_
,
_
)
=>
false
,
}
}
let
l
=
root
.clone
();
let
r
=
root
.clone
();
is_mirror
(
&
l
,
&
r
)
}
}
#[cfg(test)]
mod
test
{
use
std
::
cell
::
RefCell
;
use
std
::
rc
::
Rc
;
use
crate
::
pre_structs
::{
Solution
,
TreeNode
};
#[test]
fn
is_symmetric
()
{
let
e2
=
Some
(
Rc
::
new
(
RefCell
::
new
(
TreeNode
{
val
:
2
,
left
:
None
,
right
:
None
,
})));
let
e1
=
Some
(
Rc
::
new
(
RefCell
::
new
(
TreeNode
{
val
:
2
,
left
:
None
,
right
:
None
,
})));
let
root1
=
Some
(
Rc
::
new
(
RefCell
::
new
(
TreeNode
{
val
:
1
,
left
:
e1
,
right
:
e2
,
})));
let
ret
=
Solution
::
is_symmetric
(
root1
);
assert
!
(
ret
)
}
}
rust-leetcode/src/main.rs
浏览文件 @
93a7b038
...
...
@@ -19,6 +19,7 @@ pub mod interview_54;
pub
mod
interview_55_1
;
pub
mod
interview_58_2
;
pub
mod
leetcode_100
;
pub
mod
leetcode_101
;
pub
mod
leetcode_1021
;
pub
mod
leetcode_1051
;
pub
mod
leetcode_108
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录