Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
GreyZeng
algorithm
提交
34a8457b
A
algorithm
项目概览
GreyZeng
/
algorithm
通知
10
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
A
algorithm
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
34a8457b
编写于
1月 23, 2024
作者:
GreyZeng
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
update code
上级
026c6637
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
82 addition
and
73 deletion
+82
-73
README.md
README.md
+9
-1
src/main/java/git/snippet/queueandstack/LeetCode_0641_DesignCircularDeque.java
...ppet/queueandstack/LeetCode_0641_DesignCircularDeque.java
+73
-72
未找到文件。
README.md
浏览文件 @
34a8457b
...
...
@@ -61,9 +61,17 @@
[
荷兰国旗问题与快速排序算法
](
https://www.cnblogs.com/greyzeng/p/16739515.html
)
[
找到数组中出现特定次数数字的问题
](
https://www.cnblogs.com/greyzeng/p/15385402.html
)
-
一个数组中有一种数出现了奇数次,其他数都出现了偶数次,怎么找到并打印这种数?
-
一个数组中有两种数出现了奇数次,其他数都出现了偶数次,怎么找到并打印这两种数
-
一个数组中有一种数出现 k 次,其他数都出现了 m 次,m > 1, k < m, 找到出现了 k 次的数
-
一个数组中有一种数出现 k 次,其他数都出现了 m 次,m > 1, k < m, 找到出现了 k 次的数
[
栈和队列相关的一些问题
](
https://www.cnblogs.com/greyzeng/p/16631644.html
)
-
最小栈
-
用双向链表实现双端队列
-
栈和队列之间互相实现
-
数组实现固定大小的队列
## 更多
...
...
src/main/java/git/snippet/queueandstack/LeetCode_0641_DesignCircularDeque.java
浏览文件 @
34a8457b
...
...
@@ -6,90 +6,101 @@ package git.snippet.queueandstack;
public
class
LeetCode_0641_DesignCircularDeque
{
class
MyCircularDeque
{
Node
head
;
Node
tail
;
int
size
;
int
capacity
;
private
class
Node
{
int
v
;
Node
last
;
Node
next
;
public
Node
(
int
val
)
{
v
=
val
;
}
}
private
Node
head
;
// 头节点
private
Node
tail
;
// 尾部节点
private
int
cap
;
// 容量
private
int
size
;
// 当前大小
public
MyCircularDeque
(
int
k
)
{
cap
acity
=
k
;
cap
=
k
;
}
public
boolean
insertFront
(
int
value
)
{
if
(
!
isFull
())
{
if
(
head
==
null
)
{
head
=
new
Node
(
value
);
tail
=
head
;
}
else
{
Node
newH
ead
=
new
Node
(
value
);
head
.
last
=
newH
ead
;
newHead
.
next
=
head
;
head
=
newHead
;
}
size
++
;
return
true
;
if
(
isFull
())
{
return
false
;
}
size
++
;
if
(
head
==
null
)
{
h
ead
=
new
Node
(
value
);
tail
=
h
ead
;
}
else
{
Node
newHead
=
new
Node
(
value
)
;
newHead
.
next
=
head
;
head
.
last
=
newHead
;
head
=
newHead
;
}
return
fals
e
;
return
tru
e
;
}
public
boolean
insertLast
(
int
value
)
{
if
(!
isFull
())
{
if
(
head
==
null
)
{
head
=
new
Node
(
value
);
tail
=
head
;
}
else
{
Node
newTail
=
new
Node
(
value
);
tail
.
next
=
newTail
;
newTail
.
last
=
tail
;
tail
=
newTail
;
}
size
++;
return
true
;
if
(
isFull
())
{
return
false
;
}
return
false
;
size
++;
if
(
head
==
null
)
{
head
=
new
Node
(
value
);
tail
=
head
;
}
else
{
Node
newTail
=
new
Node
(
value
);
tail
.
next
=
newTail
;
newTail
.
last
=
tail
;
tail
=
newTail
;
}
return
true
;
}
public
boolean
deleteFront
()
{
if
(!
isEmpty
())
{
if
(
size
==
1
)
{
head
=
null
;
tail
=
null
;
size
=
0
;
return
true
;
}
else
{
Node
t
=
head
.
next
;
t
.
last
=
null
;
head
=
t
;
size
--;
}
return
true
;
if
(
size
==
0
||
cap
==
0
)
{
return
false
;
}
size
--;
if
(
size
==
0
)
{
head
=
null
;
tail
=
null
;
}
else
{
head
=
head
.
next
;
head
.
last
=
null
;
}
return
fals
e
;
return
tru
e
;
}
public
boolean
deleteLast
()
{
if
(!
isEmpty
())
{
if
(
size
==
1
)
{
head
=
null
;
tail
=
null
;
size
=
0
;
return
true
;
}
else
{
Node
t
=
tail
.
last
;
t
.
next
=
null
;
tail
=
t
;
size
--;
}
return
true
;
if
(
size
==
0
||
cap
==
0
)
{
return
false
;
}
return
false
;
size
--;
if
(
size
==
0
)
{
head
=
null
;
tail
=
null
;
}
else
{
tail
=
tail
.
last
;
tail
.
next
=
null
;
}
return
true
;
}
public
int
getFront
()
{
return
isEmpty
()
?
-
1
:
head
.
v
;
if
(
size
==
0
)
{
return
-
1
;
}
return
head
.
v
;
}
public
int
getRear
()
{
return
isEmpty
()
?
-
1
:
tail
.
v
;
if
(
size
==
0
)
{
return
-
1
;
}
return
tail
.
v
;
}
public
boolean
isEmpty
()
{
...
...
@@ -97,17 +108,7 @@ public class LeetCode_0641_DesignCircularDeque {
}
public
boolean
isFull
()
{
return
capacity
==
size
;
}
class
Node
{
public
int
v
;
public
Node
next
;
public
Node
last
;
public
Node
(
int
v
)
{
this
.
v
=
v
;
}
return
size
==
cap
;
}
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录