Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
wushizhenking
JavaGuide
提交
d0341c62
J
JavaGuide
项目概览
wushizhenking
/
JavaGuide
与 Fork 源项目一致
从无法访问的项目Fork
通知
2
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
J
JavaGuide
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
提交
d0341c62
编写于
4月 19, 2020
作者:
S
shuang.kou
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[feat]程序设计题更新
上级
059c5b93
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
21 addition
and
16 deletion
+21
-16
docs/java/java-programming-problem/Java程序设计题.md
docs/java/java-programming-problem/Java程序设计题.md
+21
-16
media/pictures/java/my-lru-cache/ConcurrentLinkedQueue-Diagram.png
...tures/java/my-lru-cache/ConcurrentLinkedQueue-Diagram.png
+0
-0
media/pictures/java/my-lru-cache/MyLRUCachePut.png
media/pictures/java/my-lru-cache/MyLRUCachePut.png
+0
-0
未找到文件。
docs/java/Java程序设计题.md
→
docs/java/
java-programming-problem/
Java程序设计题.md
浏览文件 @
d0341c62
## 泛型的实际应用
<!-- TOC -->
### 实现最小值函数
-
[
0.0.1. 泛型的实际应用:实现最小值函数
](
#001-%e6%b3%9b%e5%9e%8b%e7%9a%84%e5%ae%9e%e9%99%85%e5%ba%94%e7%94%a8%e5%ae%9e%e7%8e%b0%e6%9c%80%e5%b0%8f%e5%80%bc%e5%87%bd%e6%95%b0
)
-
[
0.0.2. 使用数组实现栈
](
#002-%e4%bd%bf%e7%94%a8%e6%95%b0%e7%bb%84%e5%ae%9e%e7%8e%b0%e6%a0%88
)
-
[
0.0.3. 实现线程安全的 LRU 缓存
](
#003-%e5%ae%9e%e7%8e%b0%e7%ba%bf%e7%a8%8b%e5%ae%89%e5%85%a8%e7%9a%84-lru-%e7%bc%93%e5%ad%98
)
<!-- /TOC -->
### 0.0.1. 泛型的实际应用:实现最小值函数
自己设计一个泛型的获取数组最小值的函数.并且这个方法只能接受Number的子类并且实现了Comparable接口。
...
...
@@ -23,10 +29,7 @@ int minInteger = min(new Integer[]{1, 2, 3});//result:1
double
minDouble
=
min
(
new
Double
[]{
1.2
,
2.2
,
-
1
d
});
//result:-1d
String
typeError
=
min
(
new
String
[]{
"1"
,
"3"
});
//报错
```
## 数据结构
### 使用数组实现栈
### 0.0.2. 使用数组实现栈
**自己实现一个栈,要求这个栈具有`push()`、`pop()`(返回栈顶元素并出栈)、`peek()` (返回栈顶元素不出栈)、`isEmpty()`、`size()`这些基本的方法。**
...
...
@@ -39,14 +42,14 @@ public class MyStack {
private
int
count
;
//栈中元素数量
private
static
final
int
GROW_FACTOR
=
2
;
//
TODO:
不带初始容量的构造方法。默认容量为8
//不带初始容量的构造方法。默认容量为8
public
MyStack
()
{
this
.
capacity
=
8
;
this
.
storage
=
new
int
[
8
];
this
.
count
=
0
;
}
//
TODO:
带初始容量的构造方法
//带初始容量的构造方法
public
MyStack
(
int
initialCapacity
)
{
if
(
initialCapacity
<
1
)
throw
new
IllegalArgumentException
(
"Capacity too small."
);
...
...
@@ -56,7 +59,7 @@ public class MyStack {
this
.
count
=
0
;
}
//
TODO:
入栈
//入栈
public
void
push
(
int
value
)
{
if
(
count
==
capacity
)
{
ensureCapacity
();
...
...
@@ -64,14 +67,14 @@ public class MyStack {
storage
[
count
++]
=
value
;
}
//
TODO:
确保容量大小
//确保容量大小
private
void
ensureCapacity
()
{
int
newCapacity
=
capacity
*
GROW_FACTOR
;
storage
=
Arrays
.
copyOf
(
storage
,
newCapacity
);
capacity
=
newCapacity
;
}
//
TODO:
返回栈顶元素并出栈
//返回栈顶元素并出栈
private
int
pop
()
{
if
(
count
==
0
)
throw
new
IllegalArgumentException
(
"Stack is empty."
);
...
...
@@ -79,7 +82,7 @@ public class MyStack {
return
storage
[
count
];
}
//
TODO:
返回栈顶元素不出栈
//返回栈顶元素不出栈
private
int
peek
()
{
if
(
count
==
0
){
throw
new
IllegalArgumentException
(
"Stack is empty."
);
...
...
@@ -88,12 +91,12 @@ public class MyStack {
}
}
//
TODO:
判断栈是否为空
//判断栈是否为空
private
boolean
isEmpty
()
{
return
count
==
0
;
}
//
TODO:
返回栈中元素的个数
//返回栈中元素的个数
private
int
size
()
{
return
count
;
}
...
...
@@ -121,4 +124,7 @@ for (int i = 0; i < 8; i++) {
}
System
.
out
.
println
(
myStack
.
isEmpty
());
//true
myStack
.
pop
();
//报错:java.lang.IllegalArgumentException: Stack is empty.
```
\ No newline at end of file
```
media/pictures/java/my-lru-cache/ConcurrentLinkedQueue-Diagram.png
0 → 100644
浏览文件 @
d0341c62
49.8 KB
media/pictures/java/my-lru-cache/MyLRUCachePut.png
0 → 100644
浏览文件 @
d0341c62
127.2 KB
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录