茶叶网站建设规划书,wordpress主题滑动,建设工程管理网站,杭州网站建设 博客文章目录一、栈的概念及使用1.1 概念1.2 栈的使用1.3 栈的模拟实现二、队列的概念及使用2.1 概念2.2 队列的使用2.3 双端队列(Deque)三、相关OJ题3.1 用队列实现栈。3.2 用栈实现队列。总结一、栈的概念及使用
1.1 概念
栈#xff1a;一种特殊的线性表#xff0c;其只允许在…
文章目录一、栈的概念及使用1.1 概念1.2 栈的使用1.3 栈的模拟实现二、队列的概念及使用2.1 概念2.2 队列的使用2.3 双端队列(Deque)三、相关OJ题3.1 用队列实现栈。3.2 用栈实现队列。总结一、栈的概念及使用
1.1 概念
栈一种特殊的线性表其只允许在固定的一端进行插入和删除元素操作。进行数据插入和删除操作的一端栈顶另一端称为栈底。栈中的数据元素遵循后进先出的原则。
压栈栈的插入操作叫做进栈/压栈/入栈入数据在栈顶。
出栈栈的删除操作叫做出栈出数据在栈顶。
1.2 栈的使用
方法功能Stack()构造一个空的栈E push(E e)将e入栈并返回eE pop()将栈顶元素出栈并返回E peek()获取栈顶元素int size()获取栈中有效元素个数boolean empty()检测栈是否为空
public static void main(String[] args) {StackInteger s new Stack();s.push(1);s.push(2);s.push(3);s.push(4);System.out.println(s.size()); // 获取栈中有效元素个数--- 4System.out.println(s.peek()); // 获取栈顶元素--- 4s.pop(); // 4出栈栈中剩余1 2 3栈顶元素为3System.out.println(s.pop()); // 3出栈栈中剩余1 2 栈顶元素为3if(s.empty()){System.out.println(栈空);}else{System.out.println(s.size());}
}1.3 栈的模拟实现 从上图中可以看到Stack继承了Vector,Vector和ArrayList类似都是动态的顺序表不同的是Vector是线程安全的。
public class MyStack {int[] array;int size;public MyStack(){array new int[3];}public int push(int e){ensureCapacity();array[size] e;return e;}public int pop(){int e peek();size--;return e;}public int peek(){if(empty()){throw new RuntimeException(栈为空无法获取栈顶元素);}return array[size-1];}public int size(){return size;}public boolean empty(){return 0 size;}private void ensureCapacity(){if(size array.length){array Arrays.copyOf(array, size*2);}}
}二、队列的概念及使用
2.1 概念
队列只允许在一端进行插入数据操作在另一端进行删除数据操作的特殊线性表队列具有先进先出的特点。
入队列进行插入操作的一端称为队尾。
出队列进行删除操作的一端称为队头。
2.2 队列的使用
在java中Queue是个接口底层是通过链表实现的。
方法功能boolean offer(E e)入队列E pool()出队列peek()获取队头元素int size()获取队列中有效元素个数boolean isEmpty()检测元素是否为空
注意Queue是个接口在实例化时必须实例化LinkedList的对象因为LinkedList实现了Queue接口。
public static void main(String[] args) {QueueInteger q new LinkedList();q.offer(1);q.offer(2);q.offer(3);q.offer(4);q.offer(5); // 从队尾入队列System.out.println(q.size());System.out.println(q.peek()); // 获取队头元素q.poll();System.out.println(q.poll()); // 从队头出队列并将删除的元素返回if(q.isEmpty()){System.out.println(队列空);}else{System.out.println(q.size());}
}2.3 双端队列(Deque)
双端队列(deque)是指允许两端都可以进行入队和出队操作的队列deque是double ended queue的简称。那就说明元素可以从队头出队和入队也可以从队尾出队和入队。
Deque是一个接口使用时必须创建LinkedList的对象。
在实际工程中使用Deque接口是比较多的栈和队列均可以使用该接口。
DequeInteger stack new ArrayDeque(); //双端队列的线性实现
DequeInteger queue new LinkedList(); //双端队列的链式实现三、相关OJ题
3.1 用队列实现栈。
OJ链接
代码如下
class MyStack {private QueueInteger qu1;private QueueInteger qu2;public MyStack() {qu1 new LinkedList();qu2 new LinkedList();}public void push(int x) {if(!qu1.isEmpty()) {qu1.offer(x);}else if (!qu2.isEmpty()) {qu2.offer(x);}else {qu1.offer(x);}}public int pop() {if(empty()) {return -1;}if(!qu1.isEmpty()) {int size qu1.size();for (int i 0; i size-1; i) {int val qu1.poll();qu2.offer(val);}return qu1.poll();}else {int size qu2.size();for (int i 0; i size-1; i) {int val qu2.poll();qu1.offer(val);}return qu2.poll();}}public int top() {if(empty()) {return -1;}if(!qu1.isEmpty()) {int size qu1.size();int val -1;for (int i 0; i size; i) {val qu1.poll();qu2.offer(val);}return val;}else {int size qu2.size();int val -1;for (int i 0; i size; i) {val qu2.poll();qu1.offer(val);}return val;}}public boolean empty() {return qu1.isEmpty() qu2.isEmpty();}
}3.2 用栈实现队列。
OJ链接
代码如下
class MyQueue {private StackInteger stack1;private StackInteger stack2;public MyQueue() {stack1 new Stack();stack2 new Stack();}public void push(int x) {stack1.push(x);}public int pop() {if(empty()) {return -1;}if(stack2.empty()) {while (!stack1.empty()) {stack2.push(stack1.pop());}}return stack2.pop();}public int peek() {if(empty()) {return -1;}if(stack2.empty()) {while (!stack1.empty()) {stack2.push(stack1.pop());}}return stack2.peek();}public boolean empty() {return stack1.isEmpty() stack2.isEmpty();}
}总结
以上就是今天要讲的内容本文仅仅简单介绍了栈与队列的概念及其使用栈与队列在解决实际问题中有着很大的作用我们需要多练习熟能生巧。