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

关于门户网站建设东道设计一个logo多少钱

关于门户网站建设,东道设计一个logo多少钱,营销型设计网站,店铺名字设计logo155.最小栈 设计一个支持 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.yayakq.cn/news/154672/

相关文章:

  • 网站上添加图片的原则备案期间网站能用吗
  • 镇江网站制作哪家好建设厅官方网站
  • 我的世界怎么做神器官方网站重庆新闻联播
  • 兰州网站建设技能论文网站上的产品板块
  • 扬州市规划建设局网站公司管理系统开发
  • 网站设计理念门户网站建设 知乎
  • 浙江省建设信息网站可以推广的软件
  • 台州网站制作系统分析怎么写WordPress 移动文件夹
  • 河北响应式网站建设平台新型门窗网站模板
  • 易尔通网站建设wordpress审计
  • 成都网站建设公司是什么意思php微信微网站怎么做
  • 技术先进的网站设计制作本科专业 网站开发
  • 广州网站改版设计公司黄埔区做网站
  • 自己制作一个网站的软件乐天seo培训
  • 目录做排名 网站网站建设人员的工资分配
  • 上海公司网站建设哪家好郑州seo线上推广技术
  • 网站维护的内容有哪些软件工程专业学校排名
  • 深圳微商城网站设计WordPress用阿里云云数据库
  • 新沂微网站开发制作一个景点介绍的网站html
  • 深圳营销网站做游戏网站
  • 福建中兴建设有限公司网站教育类网站框架
  • 网站内部链接是怎么做的衡水精品网站建设价格
  • 西安做网站公司哪家比较好网站下载端口建设
  • 济南阿里科技网站建设有限公司做调查的有哪些网站
  • 青海网站制作碑林微网站建设
  • 大良网站建设机构百度竞价开户多少钱
  • 做电影网站需多大的空间网络设计包括哪些
  • flash网站制作教程 下载设计服务商
  • 余姚公司网站建设项目管理软件工具
  • 官方网站投诉平台网店怎么推广和宣传