java栈API_Java中关于栈、队列、堆、平衡树,都有什么api,可以直接调用的接口函数...

java.util;

Stack 类表示后进先出(LIFO)对象堆栈。 它使用五个操作扩展了类Vector,这些操作允许将向量视为堆栈。

Stack stack = new Stack<>(); //新建堆栈

stack.push(1) ; //向stack栈顶压入一个元素

stack.pop() ; //从stack中弹出栈顶元素

stack.peek() ; //查看stack中栈顶元素,不弹出

stack.empty() ; //判断stack是否是空栈

stack.search(2) ; //若该对象存在,返回对象在此堆栈上的从1开始的位置。

// 栈顶元素为对象时,返回1//若不存在,则返回-1,

Deque接口及其实现提供了一套更完整,更一致的LIFO堆栈操作,应优先使用此类。

(Deque意为双端队列,double ended queue)。具体来说又有ArrayDeuqe和LinkedList两种具体类来实现,两者的区别体现在底层分别使用数组和链表来实现。

LinkedList 是一个继承于AbstractSequentialList的双向链表。它也可以被当作堆栈、队列或双端队列进行操作。

LinkedList 实现 List 接口,能对它进行队列操作。

实现Deque接口,即能将LinkedList当作双端队列使用。

当LinkedList被当做栈来使用时,常用api及对应关系如下:

栈方法        等效方法

push(e)      addFirst(e)

pop()        removeFirst()

peek()       peekFirst()

empty()       isEmpty()  //判断是否为空

队列

java中虽然有Queue接口,单java并没有给出具体的队列实现类,而Java中让LinkedList类实现了Queue接口,所以使用队列的时候,一般采用LinkedList。因为LinkedList是双向链表,可以很方便的实现队列的所有功能。

Queue使用时要尽量避免Collection的add()和remove()方法,而是要使用offer()来加入元素,使用poll()来获取并移出元素。它们的优点是通过返回值可以判断成功与否,add()和remove()方法在失败的时候会抛出异常。 如果要使用前端而不移出该元素,使用element()或者peek()方法。

java中定义队列 一般这样定义: Queue queue = new LinkedList();

当采用LinkedList来实现时,api的使用和对用关系如下:

队列方法       等效方法

offer(e)      offer(e)/offerLast(e)  //进队列,将元素加入队列末尾

poll()        poll()/pollFirst()  //获取队列头的元素并移除

peek()        peek()/peekFirst()  //获取队列头的元素       isEmpty() //判断是否为空

Queue queue = new LinkedList<>();

queue.element();

queue.offer(1);

queue.poll();

queue.peek();

双向队列

Deque deque = new LinkedList<>();

deque.offer(1);

deque.offer(2);

deque.offerFirst(3);

deque.pollLast();

小根堆

PriorityQueue类实现了优先队列,默认是一个小根堆的形式,如果要定义大根堆,需要在初始化的时候加入一个自定义的比较器。

PriorityQueue 实现heap

minHeap:PriorityQueue默认实现小根堆

PriorityQueue minHeap = new PriorityQueue<>();

minHeap.offer(8);

minHeap.offer(5);

minHeap.offer(3);

minHeap.offer(4);

minHeap.offer(2);while(!minHeap.isEmpty()) {

System.out.println(minHeap.poll());

}

class maxComparator implements Comparator{

@Overridepublic intcompare(Integer num1, Integer num2) {return num1 >= num2 ? -1 : 1;

}

}

PriorityQueue maxHeap = new PriorityQueue<>(newmaxComparator());

maxHeap.offer(5);

maxHeap.offer(3);

maxHeap.offer(4);

maxHeap.offer(1);

maxHeap.offer(2);while(!maxHeap.isEmpty()) {

System.out.println(maxHeap.poll());

}

TreeSet

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java,常见的数据结构包括数组、链表、队列、二叉树、红黑树和B+树。 数组是一种线性数据结构,它可以存储相同类型的元素,并通过索引来访问和操作这些元素。 链表也是一种线性数据结构,它由一系列节点组成,每个节点包含数据和指向下一个节点的指针。链表可以分为单向链表和双向链表。 是一种后进先出(LIFO)的数据结构,它只允许在顶进行插入和删除操作。常见的应用场景包括函数调用、表达式求值和括号匹配等。 队列是一种先进先出(FIFO)的数据结构,它允许在队尾插入元素,在队头删除元素。常见的应用场景包括任务调度、消息传递和缓冲区管理等。 二叉树是一种树形数据结构,每个节点最多有两个子节点。它具有快速的查找和插入操作的特点,常用于排序和搜索算法。 红黑树是一种自平衡的二叉查找树,它通过颜色属性和一组规则来保持平衡。红黑树的查询和插入操作的时间复杂度都是O(log n),在Java常用于实现TreeMap和TreeSet等数据结构。 B+树是一种多路搜索树,它由m叉查找树和有序双向链表组合构成。B+树在数据库和文件系统广泛应用,它具有高效的范围查询和插入操作。 总结起来,数组适用于随机访问,链表适用于频繁的插入和删除操作,队列适用于特定的操作顺序,而二叉树、红黑树和B+树适用于快速的查找和插入操作。 #### 引用[.reference_title] - *1* [数据结构简析:队列、数组、链表、红黑树。](https://blog.csdn.net/JinxLin/article/details/107892406)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [数据结构-队列、数组、链表、树](https://blog.csdn.net/m0_66570838/article/details/129588748)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [数组、链表、队列、树](https://blog.csdn.net/lercent/article/details/127754743)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值