java中stack、queue、deque、hashmap和List的操作
本文目录
Stack
基本操作
Stack<String> stack = new Stack<>();
// 为空返回true,不为空返回false
stack.isEmpty()
// 添加元素
stack.push()
// 移除栈顶
stack.pop()
// 获取栈顶值,为空返回null,元素不出栈
stack.peek()
// 为空返回0,不为空返回一个大于1的整数
stack.size()
// 对元素进行排序,如果不指定则按照Z-A排序
stack.sort(null);
// 查找一个对象是否在堆栈中存在(true/false)
stack.contains("February");
// 栈底元素位0,输出指定位置的元素
stack.elementAt(0));
// 返回该元素的位置(栈顶为1),否则返回-1
stack.search("April");
示例
public static void stackTest() {
String[] months = { "January", "February", "March", "April", "May", "June", "July", "August", "September",
"October", "November", "December" };
Stack<String> stack = new Stack<>();
for(int i = 0; i < months.length; i ++){
stack.push(months[i]);
}
stack.sort(null);
System.out.println(stack.search("April"));
System.out.println(stack.contains("April"));
System.out.println(stack.elementAt(0));//输出指定位置的元素
System.out.println(stack.size());
for(int i = 0; i < months.length; i ++){
System.out.println(stack.pop());
}
}
// 结果
12
true
April
12
September
October
November
May
March
June
July
January
February
December
August
April
遍历
-
1 增强for循环
for(Object o : stack) { System.out.println(o); }
-
2 while循环条件判断
while(!stack.isEmpty()) { System.out.println(stack.pop()); }
-
3 Iterator迭代器
Iterator it = stack.iterator(); while (it.hasNext()) { System.out.println(it.next()); }
queue
基本操作
Queue<String> queue = new LinkedList<>();
// 将元素添加到队尾,如果成功,则返回true,否则返回false
offer()
// 将队首的元素删除,并返回该元素,如果队列为空,则返回null
poll()
// 返回队首的元素,但不进行删除操作,如果队列为空,则返回null
peek()
// 将指定的元素插入队列,成功返回true,否则异常
add()
// 返回队列的开头。如果队列为空,则引发异常。
element()
// 返回并删除队列的头部,队列为空,则引发异常
remove()
示例
public static void queueTest() {
Queue<String> queue = new LinkedList<>();
queue.offer("one");
queue.offer("two");
queue.offer("three");
queue.offer("four");
System.out.println(queue);
//从队首取出元素并删除
String poll = queue.poll();
System.out.println(poll);
System.out.println(queue);
//从队首取出元素但是不删除
String peek = queue.peek();
System.out.println(peek);
System.out.println(queue);
//遍历队列,这里要注意,每次取完元素后都会删除
//整个队列会变短,所以只需要判断队列的大小即可
while(queue.size() > 0) {
System.out.println(queue.poll());
}
}
// 结果
[one, two, three, four]
one
[two, three, four]
two
[two, three, four]
two
three
four
遍历
-
1 增强for循环
for (Object o : queue) { System.out.println(o); }
-
2 while循环条件判断
while (!queue.isEmpty()) { System.out.println(queue.poll()); }
-
3 Iterator迭代器
Iterator it = queue.iterator(); while (it.hasNext()) { System.out.println(it.next()); }
deque
基本操作
Deque<String> deque = new ArrayDeque<>();
// 在双端队列的开头添加指定的元素。如果双端队列已满,则返回false
offerFirst()
// 在双端队列的末尾添加指定的元素。如果双端队列已满,则返回false
offerLast()
// 返回双端队列的第一个元素。如果双端队列为空,则返回null。
peekFirst()
// 返回双端队列的最后一个元素。如果双端队列为空,则返回null
peekLast()
// 返回并删除双端队列的第一个元素。如果双端队列为空,则返回null
pollFirst()
// 返回并删除双端队列的最后一个元素。如果双端队列为空,则返回null
pollLast()
// 在双端队列的开头添加指定的元素,如果双端队列已满,则引发异常
addFirst()
// 在双端队列的末尾添加指定的元素,如果双端队列已满,则引发异常
addLast()
// 返回双端队列的第一个元素。如果双端队列为空,则引发异常
getFirst()
// 返回双端队列的最后一个元素。如果双端队列为空,则引发异常
getLast()
// 返回并删除双端队列的第一个元素。如果双端队列为空,则引发异常
removeFirst()
// 返回并删除双端队列的最后一个元素。如果双端队列为空,则引发异常
removeLast()
以下是Deque接口提供的用于实现堆栈的方法:
push() - 在双端队列的开头添加元素
pop() - 从双端队列的开头删除元素
peek() - 从双端队列的开头返回一个元素
示例
public static void addStrings(String num1, String num2) {
// 使用ArrayDeque类创建Deque
Deque<Integer> numbers = new ArrayDeque<>();
//添加元素到Deque
numbers.offer(1);
numbers.offerLast(2);
numbers.offerFirst(3);
System.out.println("Deque: " + numbers);
//访问Deque的元素
int firstElement = numbers.peekFirst();
System.out.println("第一个元素: " + firstElement);
int lastElement = numbers.peekLast();
System.out.println("最后一个元素: " + lastElement);
//从Deque 移除元素
int removedNumber1 = numbers.pollFirst();
System.out.println("移除第一个元素: " + removedNumber1);
int removedNumber2 = numbers.pollLast();
System.out.println("移除最后一个元素: " + removedNumber2);
System.out.println("更新后的Deque: " + numbers);
}
// 结果
Deque: [3, 1, 2]
第一个元素: 3
最后一个元素: 2
移除第一个元素: 3
移除最后一个元素: 2
更新后的Deque: [1]
遍历
-
1 增强for循环
for(Object o : deque) { System.out.println(o); }
-
2 while循环条件判断
while(deque.pollLast()!=null) { System.out.println(deque.pollLast()); } while(!deque.isEmpty()) { System.out.println(deque.pollFirst()); }
-
3 Iterator迭代器
Iterator it = deque.iterator(); while (it.hasNext()) { System.out.println(it.next()); }
hashmap
示例
public static void addStrings() {
// 创建 HashMap 对象 Sites
HashMap<Integer, String> Sites = new HashMap<Integer, String>();
// 添加键值对
Sites.put(1, "Google");
Sites.put(2, "Runoob");
Sites.put(3, "Taobao");
Sites.put(4, "Zhihu");
System.out.println(Sites);
System.out.println(Sites.size());
// 输出 key 和 value
for (Integer i : Sites.keySet()) {
System.out.println("key: " + i + " value: " + Sites.get(i));
}
// 返回所有 value 值
for (String value: Sites.values()) {
// 输出每一个value
System.out.print(value + ", ");
}
// 遍历
for (Entry<Integer, String> entry : map.entrySet()) {
entry.getKey();
entry.getValue();
}
//通过 lambda 表达式使用 forEach()
Sites.forEach((key, value) -> {
System.out.print(key + "=" + value + " ");
});
System.out.println(Sites.get(3));
Sites.remove(4);
System.out.println(Sites);
Sites.clear();
System.out.println(Sites);
}
// 结果
{1=Google, 2=Runoob, 3=Taobao, 4=Zhihu}
4
key: 1 value: Google
key: 2 value: Runoob
key: 3 value: Taobao
key: 4 value: Zhihu
Google, Runoob, Taobao, Zhihu, Taobao
{1=Google, 2=Runoob, 3=Taobao}
{}
List
基础操作
List<String> list = new ArrayList<>();
// 添加
list.add(e);
// 获取
list.get(index);
// 替换该索引位置的值
list.set(index, element);
// 按照索引删除
list.remove(index);
// 按照元素内容删除
list.remove(Object o);
// 返回true或者false
list.contains(Object o);
// 第一个该值的索引
list.indexOf();
// 最后一个该值的索引
list.lastIndexOf();
// list中的元素数的和
list.size();
// 利用list中索引位置重新生成一个新的list(截取集合)
list.subList(fromIndex, toIndex);
// 对比两个list中的所有元素
list1.equals(list2));
// list是否为空
list.isEmpty()
ArrayList
List<String> list = new ArrayList<>();
ArrayList是使用的动态数组的数据结构
ArrayList 的特点是可重复的,有序的,顺序就是储存添加时候的数据
通过一个add 添加到集合,通过get(index)取出集合中的元素 下标的位置从0开始
LinkedList
LinkedList<String> list =new LinkedList<>();
list.addFirst("first");
list.addLast("last");
LinkedList使用的是双向链表的数据结构
插入方便,任意节点之间都可以插入,但是查询并不方便,效率不高
遍历
// for循环遍历,使用get()方法获取数据
for(int i = 0; i < list.size(); i++){
System.out.println(list.get(i));
}
// for循环的简化版
for(String s: list) {
System.out.println(s);
}
// 传统迭代器方式
Iterator<String> iter = list.iterator();
while(iter.hasNext()) {
String s = iter.next();
System.out.println(s);
}
// 传统迭代器方式
for(Iterator<String> it = list.iterator(); it.hasNext();){
String value = it.next();
}
// forEach遍历
list.forEach(i -> {
System.out.println(i);
});
// stream遍历
list.stream().forEach(i -> {
System.out.println(i);
});
排序
// 排序
Collections.sort(list);
// 翻转(不排序)
Collections.sort(list);
// 自定义排序
List<String> list = new LinkedList<>();
list.add("3");
list.add("1");
list.add("2");
list.add("4");
list.add("5");
Collections.sort(list, new Comparator<String>() {
@Override
public int compare(String o1, String o2) {
return o2.compareTo(o1);
}
});
list.stream().forEach(i -> {
System.out.println(i);
});
// 输出
5
4
3
2
1