TypeScript版算法与数据结构栈

38次阅读

共计 855 个字符,预计需要花费 3 分钟才能阅读完成。

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

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

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

再来看看我们类的实例属性和构造函数,其中 MyArray 就是上一篇中实现的数组,初始状态下,我们依然会给栈一个初始的容量 10。

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~ 相关的问题也可以提 issue,看到后会第一时间回复

正文完
 0