首页 >web前端 >js教程 >JS 堆栈 DS&A 介绍

JS 堆栈 DS&A 介绍

WBOY
WBOY原创
2024-08-16 06:03:071024浏览

如果您使用任何现代设备,您可能会遇到堆栈操作,即使您没有意识到。堆栈是许多编程任务的基础,从管理函数调用到启用撤消操作。

什么是堆栈?

堆栈是一种线性数据结构,遵循以 LIFO 或 FILO 结构组织数据的操作顺序。

LIFO:后进先出。

FILO:先进后出。

堆栈用于对元素集合执行操作,例如添加和删除元素、显示顶部元素以及显示集合是否为空或已满。

例如:

当您正在使用网络浏览器访问 www.ESPN.com 时,您不小心点击了芝加哥白袜队棒球门票的广告。我们添加到我们的堆栈中,也许不是故意的,但现在它位于我们堆栈的顶部。然后我们意识到芝加哥白袜队已经连续输掉了 15 场比赛。好吧...让我们点击后退按钮(从堆栈顶部删除该元素)。

JS stacks DS&A intro

是的,就是上面那个。这演示了堆栈操作中的后进先出原则,我们将从历史记录(或堆栈)中删除(删除)最后访问的页面以返回 www.ESPN.com ...也许明年是白袜队的。

堆栈操作经常用于需要维护顺序 Web 浏览器历史记录、文本编辑器上的撤消和重做以及函数调用堆栈等的应用程序。

更改堆栈时常用的函数如下:

.Push = 将元素添加到堆栈中。

.pop = 从堆栈中删除顶部元素。

.peek = 显示堆栈顶部元素。

.length/.size = 确定堆栈中索引的总数。 JavaScript 使用 (.length)

.isEmpty = 检查堆栈是否为空。

.isFull = 检查堆栈是否已满;如果数组有固定大小。

Stacks 数据结构可以使用 stacks 类或常规数组创建。

在没有类的情况下实现堆栈:

在没有 stacks 类的情况下执行堆栈操作时,我们用数组模拟堆栈操作。

下面将是一个使用堆栈操作来反转数字数组的示例。我将使用 JSON.stringify 将数组结果的值与所需的数组结果进行比较。

例如:

// Reverse an array using stack operations

let number = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]; // original array
let numberList = [9, 8, 7, 6, 5, 4, 3, 2, 1, 0]; // reversed array
let ordernumberList = []; // array to store the reversed order

// Loop through the numberList array to reverse its order
for (var i = 0; i < number.length; i++) {
  let currentValue = numberList.pop(); // using the key .pop method to remove the last element from numberList
  ordernumberList.push(currentValue); // using the key .push method to push the popped element into ordernumberList
}

console.log(ordernumberList + " vs " + number); // compare the arrays

// Convert both arrays into JSON strings for comparison
if (JSON.stringify(ordernumberList) === JSON.stringify(number)) {
  console.log("The number list is reversed: " + ordernumberList);
  return ordernumberList;
} else {
  console.log("The number list is not reversed: " + ordernumberList);
}

我想强调最后的 if-else 语句。我使用 JSON.stringify 方法来比较两个数组,因为如果没有它,比较将返回 false,从而触发 else 条件,即使数组具有相同的内容。发生这种情况是因为,在 JavaScript 中比较数组时,比较检查的是它们的引用(即它们的内存位置),而不是数组内的实际内容。

正如我们在整个 for 循环中看到的,我们的方法 .pop (删除)首先(LIFO)numberList 数组中的最后一个索引。然后使用 .push 方法将其添加到新数组 ordernumberList 中,将原始数组反转。

FILO 出现在新数组中,如果使用堆栈操作进行修改,则推入 ordernumberList 数组的第一个索引将是最后一个索引 (FILO)。

在本文中,我们探索了堆栈如何使用 LIFO 和 FILO 原理进行操作,并在 JavaScript 中实现了堆栈操作。了解堆栈对于许多编程任务至关重要,正如在网页浏览等现实场景中所见。

以上是JS 堆栈 DS&A 介绍的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn