队列和栈

队列遵循先进先出(FIFO First Input First Output )的原则。

Queue接口,同时使得LinkedList实现了该接口(选择LinkedList实现Queue的原因在于Queue经常要进行插入和删除的操作,而LinkedList在这方面效率较高)。

  • boolean offer(E e):将元素追加到队列末尾,若添加成功则返回true。
  • E poll():从队首删除并返回该元素。
  • E peek():返回队首元素,但是不删除
  1. Queue<String> queue = new LinkedList<String>();
  2. queue.offer("a");
  3. queue.offer("b");
  4. queue.offer("c");
  5. System.out.println(queue); // [a, b, c]
  6. String str = queue.peek();
  7. System.out.println(str); // a
  8. while (queue.size() > 0) {
  9.     str = queue.poll();
  10.     System.out.print(str + " "); // a b c
  11. }
  12. Deque是Queue的子接口,定义了所谓“双端队列”即从队列的两端分别可以入队(offer)和出队(poll),LinkedList实现了该接口。
  13. 如果将Deque限制为只能从一端入队和出队,则可实现“栈”(Stack)的数据结构,对于栈而言,入栈称之为push,出栈称之为pop。

    遵循先进后出(FILO First Input Last Output )的原则

  • void push(E e):将给定元素"压入"栈中。存入的元素会在栈首。即:栈的第一个元素
  • E pop():将栈首元素删除并返回。
      1. Deque<String> stack = new LinkedList<String>();
      2. stack.push("a");
      3. stack.push("b");
      4. stack.push("c");
      5. System.out.println(stack); // [c, b, a]
      6. String str = stack.peek();
      7. System.out.println(str); // c
      8. while (stack.size() > 0) {
      9.     str = stack.pop();
      10.     System.out.print(str + " "); // c b a
      11. }

      LinkedHashMap实现有序的Map

    • Map 接口的哈希表和链表实现,具有可预知的迭代顺序。此实现与 HashMap 的不同之处在于,LinkedHashMap维护着一个双向循环链表。此链表定义了迭代顺序,该迭代顺序通常就是将存放元素的顺序。

      需要注意的是,如果在Map中重新存入以有的key,那么key的位置会不会发生改变,只是将value值替换。

转载于:https://www.cnblogs.com/jcfxl/p/5735132.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值