回顾
集合框架
data:image/s3,"s3://crabby-images/4cd7e/4cd7e9be350f18a921c3e667ad2c0586c12ab676" alt=""
两个重点------ArrayList和HashSet.
data:image/s3,"s3://crabby-images/f6d47/f6d47e5bdb62ce37bb3a1b146b3694ff9d1a7f55" alt=""
Vector/ArraysList/LinkedList区别
Vector | ArraysList | LinkedList | |
---|---|---|---|
底层实现 | 数组 | 数组 | 链表 |
线程安全 | 安全 | 不安全 | 不安全 |
增删效率 | 较低 | 较低 | 高 |
扩容 | *2 | *1.5 | -------- |
data:image/s3,"s3://crabby-images/1abf4/1abf46a2670b61863c0ea348924792de10b3b61f" alt=""
(>>)运算级最低,记得加括号。
常用Api
List*
remove()的两种删除
data:image/s3,"s3://crabby-images/db950/db950ea4c35bd3dcce30d265f3027fcf2190969d" alt=""
API | 解释 | |
---|---|---|
1 | add() | 添加 |
2 | remove(index) | 索引删除 |
3 | remove(Object) | 对象删除 |
4 | set(index,e)《Set》 | 修改 |
5 | clear() | 清空 |
6 | size() | 长度 |
7 | get(index)《List》 | 查询 |
8 | indexOf()《List》 | 找出位置 |
9 | contains(用前要重写) | 包含 |
10 | isEmpty() | 集合为空 |
11 | itreator() | 迭代器(遍历和删除) |
12 | toString() | 转换为字符串 |
数组比较
Stack栈
后进先出
栈是一种特殊的数据结构,后进先出。
结构
底层还是数组。Vector派生出来的,继承Vector。
data:image/s3,"s3://crabby-images/e4ca9/e4ca91cafdc0e5cb77ea6e94f4292ba0368fef91" alt=""
Api方法
data:image/s3,"s3://crabby-images/3aa49/3aa49b7244f20968fc430d020d23297bbc9b88f1" alt=""
push():入栈
data:image/s3,"s3://crabby-images/518b7/518b7a4b32671444e7cef96b0e46d3ddbb793c66" alt=""
peek():栈顶
取栈顶不会删除栈顶。
System.out.println("栈顶:"+stack.peek());//栈顶------最后进栈的
pop():出栈
出栈会删除栈顶元素。
System.out.println("wu:"+stack.pop());//出栈
data:image/s3,"s3://crabby-images/aa9ad/aa9adc59527a0570935501c13dcd810a78d7d0c7" alt=""
完整代码:
package com.ffyc.Stack;
import java.util.Stack;
public class StackDemo01 {
public static void main(String[] args) {
Stack<Integer> stack = new Stack<>();
//存------压栈
stack.push(1);
stack.push(2);
stack.push(3);
stack.push(4);
stack.push(5);
System.out.println("栈:"+stack);
System.out.println("栈顶:"+stack.peek());//栈顶------最后进栈的
//System.out.println("wu:"+stack.pop());//出栈
//倒序打印
while (stack.size()>0){
int temp = stack.pop();//pop()后当前的栈顶元素自动删除
System.out.println(temp);
}
}
}
反转"hello"
data:image/s3,"s3://crabby-images/6f9bf/6f9bf7cee40ebdfe1fdf97624dc3c88f925fe4e1" alt=""
中间的回文数量的题可以用
计算器题目
准备工作
data:image/s3,"s3://crabby-images/88786/8878692b3e7829209a645389e4e87a72a1515764" alt=""
length-1 否则越界
data:image/s3,"s3://crabby-images/8b45c/8b45cc01a1157e3d2668a03d16f280a8bc5dba32" alt=""
data:image/s3,"s3://crabby-images/8adba/8adbafaf9fd3664f6df2ac4d1f31c49d52b52797" alt=""
Queue队列
data:image/s3,"s3://crabby-images/73daf/73daf0f9b496e3d70c4aae62e6c004fb8c957c88" alt=""
offer()进
队头添加数据
poll()出
从队头取出元素/数据
peek()顶
取出最先进队的元素。第一个offer()进去的元素。
data:image/s3,"s3://crabby-images/20791/20791b73af0ea567c719deba31e847167245c86e" alt=""
是下面代码的输出:queue.peek--->1
队列
data:image/s3,"s3://crabby-images/dea7b/dea7b77c48b58817e0276d99511f08f840cbfcfe" alt=""
可排序的队列
data:image/s3,"s3://crabby-images/a0a9b/a0a9b6efaa7da031365f97b03dd12105067849fb" alt=""