• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    迪恩网络公众号

TypeScript算法与数据结构-栈篇

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

本文的源码在这里,可以参考一下

栈也是一种使用非常广泛的线性数据结构,它具有后进先出last in first out的特点。通俗的例子就像我们平时一本一本的往上放书,等到我们又想用书时,我们首先接触到的总是我们最后一本放上去的书。
栈的添加和删除操作总是在栈的一端完成,这一端被称为栈顶,对于栈的实现,我会采用上一篇中实现的数组作为底层的数据结构,所有栈的操作都会在这个底层的数组中完成。栈的主要操作有两个,一个是入栈,一个是出栈
首先我们会定义一个TypeScript接口,这个接口会包含基础的栈类的实现

interface Stack<E> {
    getSize(): number; // 获取栈中元素的个数
    isEmpty(): boolean; // 判断栈是否为空
    push(e: E): void; // 入栈一个元素
    pop(): E; // 出栈一个元素
    peek(): E; // 查看栈顶元素
}

再来看看我们类的实例属性和构造函数,其中MyArray就是上一篇中实现的数组

class ArrayStack<E> implements Stack<E> {
    private array: MyArray<E>;
    constructor(capacity: number = 10) {
        this.array = new MyArray<E>(capacity);
    }
}

1.入栈

在有之前数组的基础上,入栈也是一个非常简单的过程,时间复杂度是O(1)

public push(e: E): void {
    this.array.addLast(e);
}

2.出栈

出栈也是一个时间复杂度为O(1)的操作

public pop(): E {
    return this.array.removeLast();
}

更多相关数据结构,可以前往我的github。持续更新中,喜欢的话给个star~


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
TypeScript算法与数据结构-数组篇发布时间:2022-07-18
下一篇:
理解TypeScript中的泛型发布时间:2022-07-18
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap