前端算法之TypeScript包含min函数的栈实例详解

 更新时间:2022年09月26日 10:16:42   作者:神奇的程序员  
这篇文章主要为大家介绍了前端算法之TypeScript包含min函数的栈实例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

前言

基于数据结构: “栈”,实现一个min函数,调用此函数即可获取栈中的最小元素。在该栈中,调用min、push、pop的时间复杂度都是O(1)。

本文就跟大家分享下这个算法,欢迎各位感兴趣的开发者阅读本文。

思路梳理

相信大多数开发者看到这个问题,第一反应可能是每次往栈中压入一个新元素时,将栈里的所有元素排序,让最小的元素位于栈顶,这样就能在O(1)的时间内得到最小元素了。但这种思路不能保证最后入栈的元素能够最先出栈,因此这个思路行不通。

紧接着,我们可能会想到用一个变量来存放最小的元素,每次压入一个新元素入栈时,如果它比当前最小的元素还要小,则更新最小元素。这样子做目的是达到了,但是又会有另一个问题:如果当前最小元素被弹出栈了,那么如何得到下一个最小的元素?

很显然,我们仅仅添加一个变量用来存储最小元素是不够的,也就是说当最小元素被取出时,我们希望得到次最小元素。那么,我们能否用一个辅助栈专门来存放这些最小元素呢?当元素入栈时,我们就取出辅助栈中的栈顶元素将其与新加入元素做大小比较,把较小的一方压入辅助栈中。

我们通过一个例子来讲解下这个过程,如下所示:

const stack = [
  3,
  5,
  7
  12,
  1,
  9,
  0
]

入栈过程如下图所示:

出栈时,我们同时弹出两个栈的栈顶元素,获取最小元素时,我们将辅助栈的栈顶元素返回即可,过程如下图所示:

实现代码

经过前面的分析,我们已经得出了完整的思路,接下来就是编码环节了,如下所示:

export class StackContainingMinFunction extends Stack {
  private minStack: Stack;
  private dataStack: Stack;
  constructor() {
    super();
    this.minStack = new Stack();
    this.dataStack = new Stack();
  }
  public push(item: number): void {
    this.dataStack.push(item);
    if (this.minStack.size() > 0) {
      const minVal = this.minStack.peek();
      // 比较当前入栈元素与minStack中的最小元素,将小的一方入minStack
      item > minVal ? this.minStack.push(minVal) : this.minStack.push(item);
      return;
    }
    this.minStack.push(item);
  }
  public pop(): void {
    this.minStack.pop();
    this.dataStack.pop();
  }
  public min(): number | null {
    if (this.minStack.size() > 0) return this.minStack.peek();
    return null;
  }
}

注意:上述代码继承了Stack,我们在之前文章中已经实现了它,对此感兴趣的开发者请移步:数组实现栈与对象实现栈的区别

我们将上个章节的例子代入上述实现的函数中,来看下它能否正确运行。

const stackMinFn = new StackContainingMinFunction();
stackMinFn.push(3);
stackMinFn.push(5);
stackMinFn.push(7);
stackMinFn.push(12);
stackMinFn.push(1);
stackMinFn.push(9);
stackMinFn.push(0);
stackMinFn.pop();
stackMinFn.pop();
stackMinFn.pop();
console.log("当前栈内最小值为:", stackMinFn.min());

示例代码

本文所列举的代码完整版请移步:

以上就是前端算法之TypeScript包含min函数的栈实例详解的详细内容,更多关于TypeScript min函数栈的资料请关注脚本之家其它相关文章!

相关文章

  • Typescript tsconfig.json的配置详情

    Typescript tsconfig.json的配置详情

    这篇文章主要为大家介绍了Typescript tsconfig.json的配置详情示例 ,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-02-02
  • 微信小程序实现图片自适应(支持多图)

    微信小程序实现图片自适应(支持多图)

    这篇文章主要介绍了微信小程序如何实现图片自适应的相关资料,文中介绍的方法同样适应于多图,有需要的朋友可以参考借鉴,下面来一起看看吧。
    2017-01-01
  • Spartacus中navigation item reducer实现解析

    Spartacus中navigation item reducer实现解析

    这篇文章主要为大家介绍了Spartacus中navigation item reducer实现解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-07-07
  • js 获取今天以及过去日期

    js 获取今天以及过去日期

    这篇文章主要介绍了js获得当前系统日期时间以及过去系统日期时间的方法,涉及javascript操作日期时间的相关技巧,示例代码如下,需要的朋友可以参考下
    2017-04-04
  • TypeScript与JavaScript的区别分析

    TypeScript与JavaScript的区别分析

    TypeScript可以使用JavaScript中的所有代码和编程概念,TypeScript是为了使JavaScript的开发变得更加容易而创建的。推荐先精通JS的的前提下再学习TS,这样更有利于同时学习两门语言。
    2022-12-12
  • DS-SDK封装ThreeJS的三维场景核心库Viewer

    DS-SDK封装ThreeJS的三维场景核心库Viewer

    这篇文章主要为大家介绍了基于DS-SDK封装ThreeJS的三维场景核心库Viewer封装示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-10-10
  • TypeScript 交叉类型使用方法示例总结

    TypeScript 交叉类型使用方法示例总结

    这篇文章主要为大家介绍了TypeScript 交叉类型使用方法示例总结,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-08-08
  • TypeScript实现十大排序算法之冒泡排序示例详解

    TypeScript实现十大排序算法之冒泡排序示例详解

    这篇文章主要为大家介绍了TypeScript实现十大排序算法之冒泡排序示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-02-02
  • typescript type 分配条件类型示例详解

    typescript type 分配条件类型示例详解

    这篇文章主要为大家介绍了typescript type 分配条件类型示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-08-08
  • TypeScript类型操作之字符串处理功能详解

    TypeScript类型操作之字符串处理功能详解

    这篇文章主要为大家介绍了TypeScript类型操作之字符串处理功能详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-07-07

最新评论