Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
醒狮指南
JavaGuide
提交
78813345
J
JavaGuide
项目概览
醒狮指南
/
JavaGuide
与 Fork 源项目一致
从无法访问的项目Fork
通知
5
Star
1
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,发现更多精彩内容 >>
提交
78813345
编写于
7月 14, 2019
作者:
S
SnailClimb
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Create Java程序设计题.md
上级
2f0a9934
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
126 addition
and
0 deletion
+126
-0
docs/java/Java程序设计题.md
docs/java/Java程序设计题.md
+126
-0
未找到文件。
docs/java/Java程序设计题.md
0 → 100644
浏览文件 @
78813345
## 泛型的实际应用
### 实现最小值函数
自己设计一个泛型的获取数组最小值的函数.并且这个方法只能接受Number的子类并且实现了Comparable接口。
```
java
//注意:Number并没有实现Comparable
private
static
<
T
extends
Number
&
Comparable
<?
super
T
>>
T
min
(
T
[]
values
)
{
if
(
values
==
null
||
values
.
length
==
0
)
return
null
;
T
min
=
values
[
0
];
for
(
int
i
=
1
;
i
<
values
.
length
;
i
++)
{
if
(
min
.
compareTo
(
values
[
i
])
>
0
)
min
=
values
[
i
];
}
return
min
;
}
```
测试:
```
java
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"
});
//报错
```
## 数据结构
### 使用数组实现栈
**自己实现一个栈,要求这个栈具有`push()`、`pop()`(返回栈顶元素并出栈)、`peek()` (返回栈顶元素不出栈)、`isEmpty()`、`size()`这些基本的方法。**
提示:每次入栈之前先判断栈的容量是否够用,如果不够用就用
`Arrays.copyOf()`
进行扩容;
```
java
public
class
MyStack
{
private
int
[]
storage
;
//存放栈中元素的数组
private
int
capacity
;
//栈的容量
private
int
count
;
//栈中元素数量
private
static
final
int
GROW_FACTOR
=
2
;
//TODO:不带初始容量的构造方法。默认容量为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."
);
this
.
capacity
=
initialCapacity
;
this
.
storage
=
new
int
[
initialCapacity
];
this
.
count
=
0
;
}
//TODO:入栈
public
void
push
(
int
value
)
{
if
(
count
==
capacity
)
{
ensureCapacity
();
}
storage
[
count
++]
=
value
;
}
//TODO:确保容量大小
private
void
ensureCapacity
()
{
int
newCapacity
=
capacity
*
GROW_FACTOR
;
storage
=
Arrays
.
copyOf
(
storage
,
newCapacity
);
capacity
=
newCapacity
;
}
//TODO:返回栈顶元素并出栈
private
int
pop
()
{
count
--;
if
(
count
==
-
1
)
throw
new
IllegalArgumentException
(
"Stack is empty."
);
return
storage
[
count
];
}
//TODO:返回栈顶元素不出栈
private
int
peek
()
{
if
(
count
==
0
){
throw
new
IllegalArgumentException
(
"Stack is empty."
);
}
else
{
return
storage
[
count
-
1
];
}
}
//TODO:判断栈是否为空
private
boolean
isEmpty
()
{
return
count
==
0
;
}
//TODO:返回栈中元素的个数
private
int
size
()
{
return
count
;
}
}
```
验证
```
java
MyStack
myStack
=
new
MyStack
(
3
);
myStack
.
push
(
1
);
myStack
.
push
(
2
);
myStack
.
push
(
3
);
myStack
.
push
(
4
);
myStack
.
push
(
5
);
myStack
.
push
(
6
);
myStack
.
push
(
7
);
myStack
.
push
(
8
);
System
.
out
.
println
(
myStack
.
peek
());
//8
System
.
out
.
println
(
myStack
.
size
());
//8
for
(
int
i
=
0
;
i
<
8
;
i
++)
{
System
.
out
.
println
(
myStack
.
pop
());
}
System
.
out
.
println
(
myStack
.
isEmpty
());
//true
myStack
.
pop
();
//报错:java.lang.IllegalArgumentException: Stack is empty.
```
\ No newline at end of file
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录