如果您使用任何现代设备,您可能会遇到堆栈操作,即使您没有意识到。堆栈是许多编程任务的基础,从管理函数调用到启用撤消操作。
堆栈是一种线性数据结构,遵循以 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我想强调最后的 if-else 语句。我使用 JSON.stringify 方法来比较两个数组,因为如果没有它,比较将返回 false,从而触发 else 条件,即使数组具有相同的内容。发生这种情况是因为,在 JavaScript 中比较数组时,比较检查的是它们的引用(即它们的内存位置),而不是数组内的实际内容。
正如我们在整个 for 循环中看到的,我们的方法 .pop(删除)首先(LIFO)numberList 数组中的最后一个索引。然后使用 .push 方法将其添加到新数组 ordernumberList 中,将原始数组反转。
FILO 出现在新数组中,如果使用堆栈操作进行修改,则推入 ordernumberList 数组的第一个索引将是最后一个索引 (FILO)。
在本文中,我们探索了堆栈如何使用 LIFO 和 FILO 原理进行操作,并在 JavaScript 中实现了堆栈操作。理解堆栈对于许多编程任务至关重要,正如在网页浏览等现实场景中所看到的那样。
免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。
Copyright© 2022 湘ICP备2022001581号-3