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

奉贤做网站建设电商运营公司排名

奉贤做网站建设,电商运营公司排名,英山县住房和城乡建设局网站,石家庄手机网站制作多少钱155.最小栈 设计一个支持 push ,pop ,top 操作,并能在常数时间内检索到最小元素的栈。 实现 MinStack 类: MinStack() 初始化堆栈对象。void push(int val) 将元素val推入堆栈。void pop() 删除堆栈顶部的元素。int top() 获取堆栈顶部的元…

155.最小栈

设计一个支持 pushpoptop 操作,并能在常数时间内检索到最小元素的栈。

实现 MinStack 类:

  • MinStack() 初始化堆栈对象。
  • void push(int val) 将元素val推入堆栈。
  • void pop() 删除堆栈顶部的元素。
  • int top() 获取堆栈顶部的元素。
  • int getMin() 获取堆栈中的最小元素

image-20231009101448266

思路:

根据栈的先进先出的特性,对于栈来说,如果一个元素a在入栈时,栈里有其他元素b,c,d,无论这个栈在之后经历了什么操作,只要a在栈中,b,c,d就一定在栈中,因为a被弹出之前,b,c,d不会被弹出

因此,在操作过程中的任意一个时刻,只要栈顶的元素是a,那么我们就可以确定栈里面现在的元素一定是a,b,c,d

可以在每个元素a入栈时把当前栈的最小值m存储起来,在这之后无论何时,如果栈顶元素是a,就可以直接返回存储的最小值m

算法:

只需要设计一个数据结构,使得每个元素a与相应的最小值m时刻保持一一对应,因此我们可以使用一个辅助栈,与元素栈同步插入与删除,每次比较栈顶元素与插入元素的大小,保证每次栈顶元素都是最小值,该辅助栈主要是用于存储与每个元素对应的最小值

  • 当一个元素要入栈时,取当前辅助栈的栈顶存储的最小值,与当前元素比较得出最小值,将这个最小值插入辅助栈中
  • 当一个元素要出栈时,把辅助栈的栈顶元素也一并弹出
  • 在任意一个时刻,栈内元素的最小值就存储在辅助栈的栈顶元素中

image-20231009102554548

class MinStack {Deque<Integer> xStack;Deque<Integer> minStack;public MinStack() {xStack = new LinkedList<Integer>();minStack = new LinkedList<Integer>();minStack.push(Integer.MAX_VALUE);}public void push(int val) {xStack.push(val);minStack.push(Math.min(minStack.peek(),val));  //取当前辅助栈的栈顶存储的最小值}public void pop() {xStack.pop();minStack.pop();}public int top() {return xStack.peek();}public int getMin() {return minStack.peek();}
}/*** Your MinStack object will be instantiated and called as such:* MinStack obj = new MinStack();* obj.push(val);* obj.pop();* int param_3 = obj.top();* int param_4 = obj.getMin();*/
http://www.15wanjia.com/news/26838.html

相关文章:

  • 客户拒绝做网站的理由哪个搜索引擎最好用
  • 公司比较好seo怎么才能做好
  • 专门做网页的网站怎么从网上找国外客户
  • 成都网站建设及推广百度关键词投放
  • 江阴做网站seo外包优化公司
  • 西安便宜网站建设qq代刷网站推广免费
  • 怎么做同学录的网站外贸平台排名
  • 做网站论文seo网站页面优化包含
  • 微云做网站seo网页优化平台
  • 餐饮行业做网站有什么好处知乎国内电商平台有哪些
  • wordpress批量alt代码seo算法
  • 西安网站制作开发公司哪家好中国最大的企业培训公司
  • 模板手机网站建设公司杭州百度seo
  • wordpress主题如何汉化seo搜索规则
  • 企业网站建设到底应该注意什么长沙网站seo
  • b2c模式的电子商务网站有哪些株洲网站建设
  • p2p贷款网站制作短网址生成网站
  • 松江区网站制作与推广营销型网站建设公司
  • 网站建设代理如何做网络营销
  • 南京做网站价格公司怎么做网站推广
  • 滨州网站建设九鲁百度云资源搜索引擎入口
  • 深圳坪山网站制作公司百度怎么发布自己的广告
  • 百度做网站续费费用优化网站的目的
  • 免费开发平台5g站长工具seo综合查询
  • 朵以服饰 网站建设网站页面优化方案
  • 网页制作培训班前景独立站seo是什么
  • 如何将网站添加到信任站点seo关键词搜索和优化
  • 河北明迈特的网站在哪里做的软件推广的渠道是哪里找的
  • 自己公司产品网站的好处南宁seo渠道哪家好
  • 顺德网站建设效果企业宣传片制作