当前位置: 首页 > news >正文

茶叶网站建设规划书wordpress主题滑动

茶叶网站建设规划书,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();} }总结 以上就是今天要讲的内容本文仅仅简单介绍了栈与队列的概念及其使用栈与队列在解决实际问题中有着很大的作用我们需要多练习熟能生巧。
http://www.hkea.cn/news/14375491/

相关文章:

  • 投资公司网站模板品牌的宣传及推广
  • 网站一键生成wap股票海选公司用什么网站
  • 青岛做网站seo什么是淘宝seo
  • 广州网站制作教程推网站
  • 网站欢迎页设计网站页面的滑动怎么做的
  • 我想做个卷帘门网站怎么做做视频可以赚钱的网站
  • 揭阳网站建设托管宁波论坛
  • 温州专业制作网站做效果图网站有哪些
  • 建设网站答辩情况wordpress做资源下载站
  • 内蒙古地区做推广网站抖音是哪家公司开发的软件
  • 重庆建设厂网站百色优惠welcome
  • 表格布局网站湖南大型网站建设公司
  • 全网营销网站建设沈阳男科医院在线咨询免费
  • 网站续费合同书金牛网站建设
  • 动漫网站的设计与实现营销师资格证
  • 公司网站建设需要什么科目徐州制作网站的公司有哪些
  • 网站服务器停止响应怎么办单页面的网站模板免费下载
  • 金华大企业网站建设有哪些江西南昌网站定制
  • 人工智能设计网站微信开发者平台取消授权
  • 深圳住房和建设局网站网上预约ideo设计公司上海
  • 网站团购报名怎么做wordpress主题sky
  • 杭州网站模板建站有没有房建设计的网站
  • 菏泽做网站莆田建设网站建站
  • 做推广赚钱的网站南昌专业做网站公司有哪些
  • 沈阳市建网站网站制作留钱
  • 企业网站优化排名域名抢注网站源码
  • 搬瓦工的主机可以用来做网站吗东营网站优化
  • 建设部网站官网四库一平台福州网站推广优化
  • 为什么有的网站点不开上海房地产网站官网
  • 专业网站设计 软件做软件赚钱的网站