java中stack、queue、deque、hashmap和List的操作

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
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

anjushi_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值