Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
梦境迷离
Cs Summary Reflection
提交
7d147adb
C
Cs Summary Reflection
项目概览
梦境迷离
/
Cs Summary Reflection
9 个月 前同步成功
通知
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,体验更适合开发者的 AI 搜索 >>
提交
7d147adb
编写于
5月 14, 2020
作者:
梦境迷离
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
rust leetcode 665
上级
27787a4c
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
68 addition
and
0 deletion
+68
-0
rust-leetcode/README.md
rust-leetcode/README.md
+31
-0
rust-leetcode/src/Solution.rs
rust-leetcode/src/Solution.rs
+37
-0
未找到文件。
rust-leetcode/README.md
浏览文件 @
7d147adb
...
...
@@ -1571,4 +1571,35 @@ impl Solution {
chars
[
chars
.len
()
-
1
]
.len
()
as
i32
}
}
```
*
665 非递减数列
```
rust
impl
Solution
{
pub
fn
check_possibility
(
nums
:
Vec
<
i32
>
)
->
bool
{
let
mut
nums
=
nums
;
let
mut
cnt
=
0
;
if
nums
.len
()
<
2
{
return
true
;
}
//将局部调整为最优方案
//当 i 和 i+1 构成逆序时
for
i
in
0
..
nums
.len
()
-
1
{
if
nums
[
i
]
>
nums
[
i
+
1
]
{
if
i
==
0
||
nums
[
i
-
1
]
<=
nums
[
i
+
1
]
{
//如果 i-1 和 i+1 是升序排列,此时缩小 i 的值
nums
[
i
]
=
nums
[
i
+
1
];
}
else
if
nums
[
i
-
1
]
>
nums
[
i
+
1
]
{
//如果 i-1 和 i+1 是降序排列,此时增大 i+1 的值
nums
[
i
+
1
]
=
nums
[
i
];
}
else
{}
//计算需要改动的次数
cnt
+=
1
;
if
cnt
>
1
{
return
false
;
}
}
}
true
}
}
```
\ No newline at end of file
rust-leetcode/src/Solution.rs
浏览文件 @
7d147adb
...
...
@@ -2089,6 +2089,42 @@ fn leetcode_58() {
println!
(
"{}"
,
ret
);
}
///非递减数列
fn
leetcode_665
()
{
println!
(
"leetcode_665"
);
impl
Solution
{
pub
fn
check_possibility
(
nums
:
Vec
<
i32
>
)
->
bool
{
let
mut
nums
=
nums
;
let
mut
cnt
=
0
;
if
nums
.len
()
<
2
{
return
true
;
}
//将局部调整为最优方案
//当 i 和 i+1 构成逆序时
for
i
in
0
..
nums
.len
()
-
1
{
if
nums
[
i
]
>
nums
[
i
+
1
]
{
if
i
==
0
||
nums
[
i
-
1
]
<=
nums
[
i
+
1
]
{
//如果 i-1 和 i+1 是升序排列,此时缩小 i 的值
nums
[
i
]
=
nums
[
i
+
1
];
}
else
if
nums
[
i
-
1
]
>
nums
[
i
+
1
]
{
//如果 i-1 和 i+1 是降序排列,此时增大 i+1 的值
nums
[
i
+
1
]
=
nums
[
i
];
}
else
{}
//计算需要改动的次数
cnt
+=
1
;
if
cnt
>
1
{
return
false
;
}
}
}
true
}
}
let
ret
=
Solution
::
check_possibility
(
vec!
[
4
,
2
,
3
]);
println!
(
"{}"
,
ret
);
}
///所有方法调用
pub
fn
solutions
()
{
interview_58_2
();
...
...
@@ -2153,6 +2189,7 @@ pub fn solutions() {
leetcode_1207
();
leetcode_38
();
leetcode_58
();
leetcode_665
();
}
fn
print_vec
(
nums
:
Vec
<
i32
>
)
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录