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

北京住房和经济建设发展委员会网站百度提交网站

北京住房和经济建设发展委员会网站,百度提交网站,网站上传百度多久收录,可口可乐vi设计手册提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 目录 前言 一、题目-最小栈 1.题目描述 2.思路与代码 2.1 思路 2.2 代码 总结 前言 提示:这里可以添加本文要记录的大概内容: 2月18日练习内容…

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

目录

前言

一、题目-最小栈

1.题目描述

2.思路与代码

2.1 思路

2.2 代码

总结


前言

提示:这里可以添加本文要记录的大概内容:

2月18日练习内容


提示:以下是本篇文章正文内容,下面案例可供参考

一、题目-最小栈

1.题目描述

设计一个支持 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
pop、top 和 getMin 操作总是在 非空栈 上调用
push, pop, top, and getMin最多被调用 3 * 104 次

来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/min-stack
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

2.思路与代码

2.1 思路

1.因为该题目可以使用链表来实现栈,则需要先建立一个内部类ListNode,该内部类的成员变量有链表的值val,该链表的最小值min,该链表的下一个结点next

2.创建最小栈类的成员变量ListNode head;

3.实现构造函数,将head置为空

4.实现一个成员方法IsEmpty,判断该栈是否为空‘

5.对于push方法,需要先判断该栈是否为空,如果栈为空,则创建一个新结点,其值和最小值等于输入的值,下一个结点为空;如果栈不为空,则创建一个新的结点,值为输入的值,最小值为输入的值与原本栈内的最小值比较之后的较小值,next为head(因为栈为先入后出,所以第一个结点为最后加入的结点),接着将新创建的结点赋值为head

6.对于pop方法,先判断栈是否为空,若栈为空,则创建一个栈为空的异常并抛出;若栈不为空,则删除头结点head=head.next

7.对于top方法,先判断是否为空,若空,抛出栈为空的异常;若不为空,则输出head.val;

8.对于getMin方法,先判断是否为空,若空,抛出栈为空的异常;若不为空,输出head.min

2.2 代码

代码如下(示例):

class MinStack {//内部类class ListNode{private int val;private int min;    //最小值private ListNode next;public ListNode(int val,int min,ListNode next){this.val = val;this.min = min;this.next = next;}}//成员变量private ListNode head;public MinStack() {this.head = null;}public void push(int val) {//判断栈是否为空if(isEmpty()){//若栈为空,则创建一个新的结点,结点的值和最小值都为输入的值head = new ListNode(val,val,null);}else{//若栈不为空,因为栈为先入后出,则直接将新创建的新结点赋值给和蔼的即可head = new ListNode(val,Math.min(val,head.min),head);}}public void pop() {//判断链表是否为空if(isEmpty()){//当栈为空时,输出一个栈为空的异常throw new IllegalStateException("栈为空……");}else{head = head.next;}}public int top() {if(isEmpty()){//当栈为空时,输出一个栈为空的异常throw new IllegalStateException("栈为空……");}else{return head.val;}}public int getMin() {if(isEmpty()){//当栈为空时,输出一个栈为空的异常throw new IllegalStateException("栈为空……");}else{return head.min;}}//判断链表是否为空private boolean isEmpty(){return head == null;}}/*** 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.ds6.com.cn/news/120138.html

相关文章:

  • 如何看一个网站是用哪个语言做的打开百度
  • 网站的域名每年都要续费网络优化基础知识
  • 个人做网站如何赚钱吗谷歌seo价格
  • 公司网站建设的定位语要怎么取注册一个域名需要多少钱
  • 个人如何通过网站赚大钱网站seo优化排名
  • 做公众号的网站有哪些功能自媒体人专用网站
  • 公司电子邮箱怎么注册南昌seo代理商
  • 国外网站视觉设计趋势友情链接多久有效果
  • 帮忙做公司网站企业推广方法
  • 建筑公司网站制作环球网今日疫情消息
  • 苏宁易购网站建设网络营销推广工具
  • dede网站模板客推广资源网
  • 电商公司运营策略天门seo
  • 网站正在建设页面模板优化大师电脑版
  • 做的网站出现404网页游戏推广平台
  • 唐山住房和城乡建设厅网站高端seo服务
  • 工商网站官网查询湘潭seo优化
  • 如果查询网站内页的收录情况快速排名上
  • 温州微信网站定制站长工具精华
  • 跟我一起做网站pdf电驴seo培训
  • 网站长尾词品牌推广案例
  • 网站 反链企业培训视频
  • 网站建设管理工作的意见武汉seo公司排名
  • 自己可以自己做公司的网站吗推动防控措施持续优化
  • 网站建设编辑工作总结网址安全中心检测
  • 河南锦源建设有限公司网站知名网络营销推广
  • 国内论坛网站有哪些知乎关键词搜索
  • 如何做网站经营性备案网站推广及seo方案
  • 深圳高端网站制作价格百度推广客服电话24小时
  • 个人展示网站被忽悠去做网销了