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

做课件可赚钱的网站淘宝关键词优化软件

做课件可赚钱的网站,淘宝关键词优化软件,文旅网站界面设计,网页更改栈和队列 栈stack 栈也是一种线性结构相比数组#xff0c;栈对应的操作数数组的子集只能从一端添加元素#xff0c;也只能从一端取出元素这一端称为栈顶 栈是一种后进先出的数据结构Last in Firt out(LIFO)在计算机的世界里#xff0c;栈拥有者不可思议的作用 栈的应用 …栈和队列 栈stack 栈也是一种线性结构相比数组栈对应的操作数数组的子集只能从一端添加元素也只能从一端取出元素这一端称为栈顶 栈是一种后进先出的数据结构Last in Firt out(LIFO)在计算机的世界里栈拥有者不可思议的作用 栈的应用 无处不在的undo操作(撤销) 沉迷 学习 不法 程序调用的系统栈 从A函数调用B函数B函数在调用C函数A2表示进行到A函数的第二行 当一个子过程可以自动回到上层调用继续执行的原因因为有系统栈去记录每一个中断的点。子过程的调用实现机理就是如此。对于递归的理解会在后续介绍。 栈的实现 Stack void push(E)E pop()E peek()int getSize()boolean isEmpty() 从用户的角度看支持这些操作就好 具体底层实现用户不关心 实际底层有多种实现方式 采用多态的方式 public Interface StackE{int getSize();boolean isEmpty();void push(E e);E pop();E peek(); } public class ArrayStackE implements StackE{ArrayE array;public ArrayStack(int getCapacity){array new Array(capacity);}public ArrayStack(){array new Array();}Overrideint getSize(){return array.getSise; }Overrideboolean isEmpty(){return array.isEmpty();}Overridepublic int getCapacity(){return array.getCapacity();}Overridevoid push(E e){arraty.addLasy(e);}OverrideE pop(){array.removeLast();}OverrideE peek(){return array.getLast();}Overridepublic String toString(){StringBuilder res new StringBuilder();res.append(Stack: );res.append([]);for(int i 0 ; i arr.getSize();i){res.append(array.get(i));if(i!array.getSize()-1)res.append(, );}res.append(] top);return res.toString();} } 对于array新加如下方法 public E getLast(){return get(size-1); } public E getFirst(){return get(0); }栈的另一个应用括号匹配 这是二十家大公司对于该题的面试形式 栈顶元素反映了在嵌套的层次关系中最近的需要匹配的元素 Class Solution{public boolean isValid(String s){StackCharacter stack new Stack();for(int i 0 ; i s.length();i)char c s.charAt(i);if(c(||c[||c{)stack.push(c);else{if(stack.isEmpty())return false;char topChar stack.pop();if(c)topChar!()return false;if(c]topChar![)return false;if(c}topChar!{)return false;}return stack.isEmpty();} }队列 队列也是一种线性结构 相比数组队列对应的操作是数组的子集 只能从一端添加元素从另一端取出元素 队列是一种先进先出的数据结构先到先得 First I First Out(FIFO) QueueE - void enqueue(E)//入队 - E dequeue()//出队 - E getFront()//获取队首元素 - int getSize() - boolean isEmpty()//是否为空public interface QueueE{void enqueue(E)//入队E dequeue()//出队E getFront()//获取队首元素int getSize()boolean isEmpty()//是否为空 } public class ArrayQueueE implements QueueE{private ArrayE array;public ArrayQueue(int capacity){array new Array(capacity);}public ArrayQueue(){array new Array();}Overridepublic int getSize(){return array.getSize();}Overridepublic int isEmpty(){return array.isEmpty();}Overridepublic int getCapacity(){return array.getCapacity();}Overridepublic int enqueue(){array.addLast(e);}Overridepublic int dequeue(){return array.removeFirst();}Overridepublic E getFront(){return array.getFirst();}Overridepublic String toString(){StringBuilder res new StringBuilder();res.append(Queue: );res.append(front [);for(int i 0 ; i arr.getSize();i){res.append(array.get(i));if(i!array.getSize()-1)res.append(, );}res.append(] tail);return res.toString();} }循环队列 数组队列的问题 tail1)%cfront 队列满 对于循环我们可以查看自己的钟表就能理解了循环的意思。形成一个环大小由数组容积决定。 public class LoopQueueE implements QueueE{private E[] data;private int front,tail;private int size;public LoopQueue(int capacity){data (E[]) new Obejct[capacity1];front 0;tail 0;size 0;}public LoopQueue(){this(10);}public int getCapacity(){return data.length-1;}Overridepublic boolean isEmpty(){return fronttail;}Overridepublic String toString(){StringBuilder res new StringBuilder();res.append(Queue: size %d, capacity %d,size,getCapacity());res.append(front [);for(int i front ; i ! tail;(i1)%data.length){res.append(array.get(i));if((i1)%data.length!tail)res.append(, );}res.append(] tail);return res.toString();} }循环队列的实现 Overridepublic void enqueue(E e){if((tail1)%data.lengthfront)resize(getCpacity()*2);data[tail] e;tail (tail1)%data.length;size;}Overridepublic E dequeue(){if(isEmpty())throw new IllegalArgumentException(cannot dequeue from an empty queue);E ret data[front];data[front] null;front (front1)%data.length;size--;if(size getCapacity()/4resize(getCapacity()/2!0)resize(getCapacity()/2);return ret;}private void resize(int newCapacity){E[] newData (E[]) new Object[newCapacity1];for(int i 0; i size ;i){newData[i] data[(ifront) % data.length];}data newData;front 0;tail size;}Overridepublic E getFront(){if(isEmpty())throw new IllegalArgumentException(from an empty queue);return data[front];}Overridepublic String toString(){StringBuilder res new StringBuilder();res.append(Queue: size %d, capacity %d,size,getCapacity());res.append(front [);for(int i front ; i ! tail;(i1)%data.length){res.append(array.get(i));if((i1)%data.length!tail)res.append(, );}res.append(] tail);return res.toString();}数组队列和循环队列的比较 栈和队列习题集 使用动态数组实现栈和队列但是现在如果没有这种结果的话。我们需要用栈应该著怎么实现呢 使用队列实现栈 使用栈实现队列
http://www.w-s-a.com/news/850085/

相关文章:

  • 360全景网站建设常州专业网站建设公司咨询
  • 重庆大渡口网站建设网站增加一体化建设功能的好处
  • 网站开发完整视频网站上传 404
  • 自适应网站做推广北京建设工程招标网
  • 外贸网站设计注意事项网上商城官网入口
  • 正规的营销型网站建设公司微官网是网站吗
  • 南京行业门户网站无锡阿里巴巴做网站
  • 河北省和城乡住房建设厅网站wamp wordpress打不开
  • 在哪个平台做网站比较好自动app优化
  • 有没有能帮人快速网站备案的机构个人学做网站
  • 凌云县 城市建设 网站西安市建网站
  • 织梦xml网站地图公众号公众平台
  • 长春省妇幼网站做四维学校网站系统破解版
  • 安阳免费搭建自己的网站个人网站做商城会怎样
  • 网站建设专家公司排行网站举报有奖平台
  • 程序员不是做网站的公司装修效果全景图
  • 桥东区住房和建设局网站怎么做网上问卷
  • 做期货要看哪些网站伪装的福祉 wordpress
  • 做网站需要多少费用网站建设需要懂什么语言
  • 网站手机端做app开发商城设计方案
  • 在建设厅网站上查询注销建造师查域名是否注册
  • 企业网站推广方案策划公司网站在国外打开很慢使用cdn好还是国外租用服务器好
  • 龙华o2o网站建设百度不收录什么网站吗
  • 模板搭建网站百度信息流推广
  • 移动端网站制作模板自己做的网站点击赚钱
  • 网站站长如何赚钱wordpress抓取别人网站
  • 做网站媒体专门做产品定制的网站
  • 公司企业网站建设步骤免费asp网站模板
  • 台州企业网站搭建价格做留言的网站
  • 西安网站建设q.479185700強高端网站设计定制公司