# 队列的介绍

coderwhy (opens new window)

# 队列的操作

  • enqueue(element):向队列尾部添加一个(或多个)新的项。
  • dequeue():移除队列的第一(即排在队列最前面的)项,并返回被移除的元素。
  • front():返回队列中第一个元素——最先被添加,也将是最先被移除的元素。队列不做任何变动(不移除元素,只返回元素信息——与 Stack 类的 peek 方法非常类似)。
  • isEmpty():如果队列中不包含任何元素,返回 true,否则返回 false。
  • size():返回队列包含的元素个数,与数组的 length 属性类似。

# 基于数组的队列

class Queue {
  constructor() {
    this.items = [];
  }
  // enqueue(element):向队列尾部添加一个(或多个)新的项。
  enqueue(element) {
    this.items.push(element);
  }
  // dequeue():移除队列的第一(即排在队列最前面的)项,并返回被移除的元素。
  dequeue() {
    this.items.shift();
  }
  // front():返回队列中第一个元素——最先被添加,也将是最先被移除的元素。队列不做任何变动(不移除元素,只返回元素信息——与Stack类的peek方法非常类似)。
  front() {
    return this.items[0];
  }
  // isEmpty():如果队列中不包含任何元素,返回true,否则返回false。
  isEmpty() {
    return this.items.length === 0;
  }
  // size():返回队列包含的元素个数,与数组的length属性类似。
  size() {
    return this.items.length;
  }
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25

# 基于对象的队列

class Queue {
  constructor() {
    this.count = 0;
    this.lowestCount = 0;
    this.items = {};
  }
  // enqueue(element):向队列尾部添加一个(或多个)新的项。
  enqueue(element) {
    this.items[this.count] = element;
    this.count++;
  }
  // dequeue():移除队列的第一(即排在队列最前面的)项,并返回被移除的元素。
  dequeue() {
    if (this.isEmpty()) {
      return undefined;
    }
    const result = this.items[this.lowestCount];
    delete this.items[this.lowestCount];
    this.lowestCount++;
    return result;
  }
  // front():返回队列中第一个元素——最先被添加,也将是最先被移除的元素。队列不做任何变动(不移除元素,只返回元素信息——与Stack类的peek方法非常类似)。
  front() {
    if (this.isEmpty()) {
      return undefined;
    }
    return this.items[this.lowestCount];
  }
  // isEmpty():如果队列中不包含任何元素,返回true,否则返回false。
  isEmpty() {
    return this.size() === 0;
  }
  // size():返回队列包含的元素个数,与数组的length属性类似。
  size() {
    return this.count - this.lowestCount;
  }

  clear() {
    this.items = {};
    this.count = 0;
    this.lowestCount = 0;
  }

  toString() {
    if (this.isEmpty()) {
      return "";
    }
    let objString = `${this.items[this.lowestCount]}`;
    for (let i = this.lowestCount + 1; i < this.count; i++) {
      objString = `${objString},${this.items[i]}`;
    }
    return objString;
  }
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54

# 双端队列

// 双端队列:允许同时从前端和后端添加和移除元素
class Deque {
  constructor() {
    this.count = 0;
    this.lowestCount = 0;
    this.items = {};
  }
  addFront(element) {
    // 第一种场景:如果这个双端队列为空
    if (this.isEmpty()) {
      this.addBack();
    } else if (this.lowestCount > 0) {
      // 第二种场景:一个元素已经从双端队列的前端移除
      this.lowestCount--;
      this.items[this.lowestCount] = element;
    } else {
      // 第三种场景:lowestCount=0的情况
      for (let i = this.count; i > 0; i--) {
        this.items[i] = this.items[i - 1];
      }
      this.count++;
      this.lowestCount = 0;
      this.items[0] = element;
    }
  }
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26

# 循环队列

# 优先级队列

队列-搜-优先级队列 (opens new window)

实现优先级队列相对队列主要有两方面需要考虑:

  • 封装元素和优先级放在一起(可以封装一个新的构造函数)
  • 添加元素时, 将当前的优先级和队列中已经存在的元素优先级进行比较, 以获得自己正确的位置.
上次更新: 2021年10月30日星期六晚上11点23分