如果您使用任何现代设备,您可能会遇到堆栈操作,即使您没有意识到。堆栈是许多编程任务的基础,从管理函数调用到启用撤消操作。
堆栈是一种线性数据结构,遵循以 LIFO 或 FILO 结构组织数据的操作顺序。
LIFO:后进先出。
FILO:先进后出。
堆栈用于对元素集合执行操作,例如添加和删除元素、显示顶部元素以及显示集合是否为空或已满。
例如:
当您正在使用网络浏览器访问 www.ESPN.com 时,您不小心点击了芝加哥白袜队棒球门票的广告。我们添加到我们的堆栈中,也许不是故意的,但现在它位于我们堆栈的顶部。然后我们意识到芝加哥白袜队已经连续输掉了 15 场比赛。好吧...让我们点击后退按钮(从堆栈顶部删除该元素)。
是的,就是上面那个。这演示了堆栈操作中的后进先出原则,我们将从历史记录(或堆栈)中删除(删除)最后访问的页面以返回 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中文网其他相关文章!