数据结构 - 队列&栈

213 阅读2分钟

[实例]: github.com/barchielAby…

622. 设计循环队列

设计你的循环队列实现。 循环队列是一种线性数据结构,其操作表现基于 FIFO(先进先出)原则并且队尾被连接在队首之后以形成一个循环。它也被称为“环形缓冲器”。

循环队列的一个好处是我们可以利用这个队列之前用过的空间。在一个普通队列里,一旦一个队列满了,我们就不能插入下一个元素,即使在队列前面仍有空间。但是使用循环队列,我们能使用这些空间去存储新的值。

你的实现应该支持如下操作:

MyCircularQueue(k): 构造器,设置队列长度为 k 。 Front: 从队首获取元素。如果队列为空,返回 -1 。 Rear: 获取队尾元素。如果队列为空,返回 -1 。 enQueue(value): 向循环队列插入一个元素。如果成功插入则返回真。 deQueue(): 从循环队列中删除一个元素。如果成功删除则返回真。 isEmpty(): 检查循环队列是否为空。

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

export class MyCircularQueue {
  size = 0
  list: Array<number> = []
  constructor(k: number) {
    this.size = k
  }

  Front(): number {
    return this.list[0] ?? -1
  }

  Rear(): number {
    return this.list[this.list.length - 1] ?? -1
  }

  enQueue(value: number): boolean {
    if (this.isFull()) {
      return false
    }
    this.list.push(value)
    return true
  }

  deQueue(): boolean {
    if (this.isEmpty()) {
      return false
    }
    this.list.shift()
    return true
  }

  isEmpty(): boolean {
    return this.list.length === 0
  }

  isFull(): boolean {
    return this.list.length === this.size
  }
}

155. 最小栈

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

实现 MinStack 类:

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

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

class SinglyLinkedList {
  val: number
  next: SinglyLinkedList | null
  constructor(val: number) {
    this.val = val
    this.next = null
  }
}

class MinLinkedList extends SinglyLinkedList {
  min: number
  next: MinLinkedList | null
  constructor(val: number, min: number) {
    super(val)
    this.min = min
    this.next = null
  }
}

// 最小栈
class MinStack {
  head: MinLinkedList | null
  size = 0

  constructor() {
    this.head = null
  }

  push(val: number): void {
    this.size++
    const prevMin = this.head?.min ?? Infinity
    const min = val < prevMin ? val : prevMin

    const newNode: MinLinkedList = new MinLinkedList(val, min)
    if (this.head) {
      newNode.next = this.head
    }

    this.head = newNode
  }

  pop(): void {
    const node = this.head
    if (node) {
      this.head = node.next
      this.size--
    }
  }

  top(): number {
    return this.head ? this.head.val : -1
  }

  getMin(): number {
    return this.head?.min ?? -1
  }
}