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

崇明专业网站建设手机网站如何生成app

崇明专业网站建设,手机网站如何生成app,在wordpress上添加播放视频播放器,为什么电脑有些网页打不开题目 设计一个支持 push ,pop ,top 操作,并能在常数时间内检索到最小元素的栈。 实现 MinStack 类: MinStack() 初始化堆栈对象。void push(int val) 将元素val推入堆栈。void pop() 删除堆栈顶部的元素。int top() 获取堆栈顶部的元素。i…

题目

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

实现 MinStack 类:

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

示例 1:

输入:
["MinStack","push","push","push","getMin","pop","top","getMin"]
[[],[-2],[0],[-3],[],[],[],[]]输出:
[null,null,null,null,-3,null,0,-2]解释:
MinStack minStack = new MinStack();
minStack.push(-2);
minStack.push(0);
minStack.push(-3);
minStack.getMin();   --> 返回 -3.
minStack.pop();
minStack.top();      --> 返回 0.
minStack.getMin();   --> 返回 -2.

提示:

  • -231 <= val <= 231 - 1
  • poptop 和 getMin 操作总是在 非空栈 上调用
  • pushpoptop, and getMin最多被调用 3 * 104 次

自己的一些思考

我每次在看到这个题目的时候都会写一点思考,有些时候思考不一定全都对,很多时候都是一个暴力思考。但是思考的流程可能比较重要。有错误也请大家斧正,不过最后的代码一定会是修改且通过用例的。

栈是一个LIFO结构,后进先出。有三种基本的操作。1.PUSH,即把一个元素压入栈顶,push和append的效果都是一样的。可是push用在栈里面,append常见于列表。2.pop,即为去除栈顶上的元素,3.Top/peek,返回栈顶的元素

这个代码想要实现的就是写一个栈,这个栈能够有基础的操作,且能够返回最小值

class MinStack:def __init__(self):def push(self, val: int) -> None:def pop(self) -> None:def top(self) -> int:def getMin(self) -> int:# Your MinStack object will be instantiated and called as such:
# obj = MinStack()
# obj.push(val)
# obj.pop()
# param_3 = obj.top()
# param_4 = obj.getMin()

题目给的参考例子是这个,我们就拿这个来试着分析一下。

 def __init__(self):

    def push(self, val: int) -> None:

先初始化这个栈,可以写成self.stack=[],这个self指向调用的当前对象,指向对象自身的引用,能够初始化这个对象,然后这里使用的是self.stack=[],创建一个空栈

    def push(self, val: int) -> None:

这里在栈顶添加一个元素可以使用这个代码,self.stack.push(val)

    def pop(self) -> None:

这里返回最上面的这个也可以用stack里面的方法,self.stack.pop()

    def top(self) -> int:

这里要获取top,return self.stack[-1][0],最后面一个元素(可能是一个列表,返回这个列表的第一个值)

   def getMin(self) -> int:

那么我到这里的时候就会有一点迷惑,这个Min该怎么样去处理呢,于是我去看了一下题解。

题解

题解当中提到使用一个叫做“辅助栈”的概念

而且这个题解在栈中间插入了元组(里面有不同数据类型的一种数据结构,可以存储一组有序的元素)

什么是辅助栈,辅助栈最经典的例子就是这个最小栈,就是保存栈内所有元素的最小值。有新添加进来的元素都能够获取到这个的最小值,当新元素来的时候,如果它比辅助栈的栈顶元素更小,就把这个新的元素压入辅助栈,当元素出栈是,如果它和辅助栈的栈顶元素大小一致时,就把辅助栈栈顶也给弹出(POP)

class MinStack(object):def __init__(self):"""initialize your data structure here.、初始化栈"""self.stack = []def push(self, x):""":type x: int:rtype: void"""#栈内每一个元素都是一个二元组(tuple),#(x)(x)前一个(x)是真实的元素,后面一个(x)是最小#如果不是空值,就把自身和现在栈顶的二元组的1做一个比较,#哪个小,新栈顶上面的[1]就是这个元素if not self.stack:self.stack.append((x, x))else:self.stack.append((x, min(x, self.stack[-1][1])))def pop(self):""":rtype: void"""self.stack.pop()def top(self):""":rtype: int"""return self.stack[-1][0]def getMin(self):""":rtype: int"""return self.stack[-1][1]# Your MinStack object will be instantiated and called as such:
# obj = MinStack()
# obj.push(x)
# obj.pop()
# param_3 = obj.top()
# param_4 = obj.getMin()

TODO

1.第一刷:2024/3/10

2.切记辅助栈这个概念,可以通过元组这种方法来实现

http://www.yayakq.cn/news/899685/

相关文章:

  • 苏州行业网站建设报价智慧旅游网站建设方案
  • 青岛做网站哪家好湘潭关键词优化公司
  • 印度做网站需要备案吗网站设置超链接
  • 做汽车租赁主要的网站网页制作软件电脑版
  • 建设网站的相关软件可以商用的图片网站
  • 说明网站建设岗位工作职责企业网站的建立步骤
  • 张家口网站建设公司企业官网首页图片
  • 做网站实现图片自动压缩宁德网站建设51yunsou
  • 会计做帐模板网站广州网络公司策划
  • 怎样自己开网站赚钱亚马逊网站建设进度计划表
  • 工程技术研究中心网站建设要求深圳市南山区住房和建设局
  • 怀宁县住房与城乡建设局网站凡客诚品v
  • 怎么设置自己的网站那些网站可以找得到做货代的
  • 单页网站的区别建立网站公司有哪些
  • wordpress 做手机站WordPress建站收费
  • 推广平台网站热狗网小学校园网站怎么建设
  • 开发者模式怎么关闭vivo长春seo公司哪家好
  • 网站图片太多怎么优化更换域名wordpress
  • 新的网站怎么做seo普通网站怎么做h5
  • 设计很好看的网站在线代理免费
  • 企业网站管理系统教程网站关键词优化方式
  • gps建站步骤做网赌网站怎么推广
  • 企业网站建设东莞做购物网站适合的服务器
  • 阿里巴巴国际站怎么运营什么值得买 wordpress
  • 石油大学 网页设计与网站建设seo优化软件有哪些
  • 青海微信网站建设建站教程视频下载
  • 简洁商城网站模板my域名
  • html网页制作如何加入图片重庆seo职位
  • 南昌网站建设哪家好薇建设安全施工网络平台
  • 网站建设公司能赚钱吗wordpress禁用