- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在尝试更加熟悉这 4 个概念。
所以如果我们有一个数组 {15, 34, 23, 32, 15, 5}
我们有这样的操作
pop();
push(30);
enqueue(40);
dequeue(100);
pop() 只会删除第一个数字,即 15,对吗?如果它是 pop(20) 怎么办?
我假设 push(30) 会添加 30 作为最后一个数字。
入队和出队的工作方式是否与弹出和推送相同?
(那么 enqueue(40) 会在行尾添加 40 吗?dequeue(100) 会做什么?)
最佳答案
pop() would just remove the first number, which is 15, right ? what if it was pop(20) ?
我认为如果将操作与特定数据结构相关联,您会更容易理解这些概念。
例如,push(item)
和 pop()
等操作适用于堆栈,而enqueue( item)
和 dequeue()
用于队列,它们都具有特定且定义明确的行为。
堆栈仅适用于顶部的项目,例如一堆煎饼、纸张或任何其他彼此叠加的项目集合。
这意味着您的 {15, 34, 23, 32, 15, 5}
数组可以这样查看:
| 15 | <--- top
| 34 |
| 23 |
| 32 |
| 15 |
| 5 |
+----+
在这里,pop
会简单地删除顶部的元素,然后让 top
指向紧靠其下方的元素(即 34)。显然,使用 push(8)
会在堆栈顶部添加一个新元素(即 8),因此它现在看起来像这样:
| 8 | <--- top
| 34 |
| 23 |
| 32 |
| 15 |
| 5 |
+----+
由于堆栈的定义行为,像 pop(item)
这样的操作没有意义:它不再将自己限制在顶部的项目堆栈。
I'm assuming push(30) would add 30 as the last number.
这是不正确的,或者至少是模棱两可的:您认为“最后”元素在哪里? “最后”对你来说意味着什么?这里的问题是像“第一个”和“最后一个”这样的术语暗示了顺序,这是队列的意思(见后文)。然而,堆栈在这个意义上并不是有序的集合,因此在堆栈上下文中谈论第一个/最后一个元素没有多大意义。
在push
ing 和pop
ing 等堆栈操作方面,您应该始终谈论顶部 或底部 的堆栈。
Do enqueue and dequeue work the same as pop and push?
没有。 enqueue
和dequeue
等操作适用于称为队列 的不同数据结构。队列在行为方式和支持的操作方面与堆栈不同。
例如,堆栈总是在顶部添加或删除元素,而队列总是在后面添加(即入队
)项目收集和移除(即 dequeue
)前面的元素,按照先进先出 (FIFO) 的顺序。
+-- front
v
+--+----+----+----+----+---+
15 | 34 | 23 | 32 | 15 | 5 |
+--+----+----+----+----+---+
^
+-- back
如果您将队列的行为想象成商店中的一条线,那么关联结构的正确行为会更容易。每次您在商店排队时,您都在排队。
Then would enqueue(40) add 40 at the back of the line?
正确。队列现在看起来像这样:
+-- front
v
+--+----+----+----+----+---+----+
15 | 34 | 23 | 32 | 15 | 5 | 40 |
+--+----+----+----+----+---+----+
^
+-- back
What would dequeue(100) do?
这类似于我用 pop
描述的问题:它没有意义,因为 dequeue
意味着总是删除元素在前面。因此,队列只支持 dequeue()
并且它会自动删除“行”前面的任何内容:
+-- front
v
+--+----+----+----+----+---+
34 | 23 | 32 | 15 | 5 | 40 |
+--+----+----+----+----+---+
^
+-- back
关于c++ - 数据结构 : explanation of pop, push, dequeue, enqueue 在这类练习中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34199541/
我正在从不同来源获取新闻提要并添加到数据库,但我遇到异常 Error: Cannot enqueue Handshake after already enqueuing a Handshake. at
嘿,大家好,我只是想制作一个简单的表单,将数据发送到 mySQL 数据库。我的问题是提交后我无法再提交另一份。它只允许我提交表单一次,然后在第二次提交后,我收到此错误“错误:在已经排队握手后无法排队握
我每 5 秒查询一个表并向用户显示。我使用的是mysql 8。应用程序是nodejs。 var con = mysql.createConnection({ host: "localhost",
我正在尝试创建两个函数,一个从 SQL 数据库检索对象,另一个将对象保存到同一个 SQL 数据库。我使用 node.js 和 mysql 来执行此操作。我有两个函数,fetchEmployee 和 E
我需要一个具有固定容量但始终允许线程将项目添加到开头的 Java 列表。如果它已满,它应该从末尾删除一个项目以腾出空间。没有其他进程会删除项目,但其他进程会希望迭代这些项目。 JDK 中有什么东西可以
我在 tensorflow 中构建了一个卷积神经网络。它经过培训,现在我正在打开它并进行评估。 import main import Process import Input eval_dir = "
如果last会变成x,为什么last.next会被分配给x?我不明白将 x 分配给 last.next 有何影响。这是队列的完整上下文:http://introcs.cs.princeton.edu/
我在创建具有双因素身份验证的应用程序时遇到了一些麻烦。我决定使用 twilio 作为我的短信网关,并决定遵循他们的教程。然而,尽管已经导入了我需要的内容,但我遇到了无法解决排队问题。 import a
注册样式表然后将其入队与直接入队有何不同? 我在这里注册然后排队。 function calling_script(){ wp_register_style('bootstrap',
假设我有一个模块,其中有一个队列。 对于其他实体入队,它们必须通过一个函数: public sub InsertIntoQueue(Obj) MyQueue.Enqueue(Obj) end
我有一个包含 6 个库的列表,我想加载到我的 WordPress 插件/主题中。目前它们都像这样添加到主题的标题中。 我正在构建一个插件,它有自己的脚本,依赖于这些库。我想运行我提出的这个解决方案,
只需要一些关于 WP en 队列的信息,我已经在各个网站上学习了一些教程,因为我是一个非常基础的网页设计师,我主要使用 HTML CSS 至少这是我最了解的。 我无法最好地解释我哪里出了问题,但我可以
有没有办法在一定时间后重定向队列中的调用? 我在 Twiml 中知道 您可以设置超时。 有没有办法在 中做到这一点?甚至 作为它的一部分 waitURL 现在我正在做这样的事情:
目前正在准备考试,无法弄清楚示例代码中 queue[rear*] = new_node 背后的原因。 你不是把 new_node 的地址而不是值放进去吗? 还有,这个队列是不是Node**队列,因为它
我是编程新手。尝试编写一个函数来接收列表的头部 + 要插入的数据 - 并传回列表的新头部。我已经通过将元素添加到列表的头部来完成很多工作,但出于某种原因,我无法理解这个细微的差别。 #include
我是队列实现的新手,需要一些帮助来练习。 假设我正在使用 enqueue 对 4 个人进行排队,并且我想向输出添加一个函数,以显示 1 到 10 之间的随机数“x”4 次,并符合以下条件: 如果“x”
首先,我将解释一个简短的场景; 当来自某些设备的信号触发时,一个类型为 Alarm 的对象被添加到队列中。每隔一段时间检查队列,并针对队列中的每个警报触发一个方法。 但是,我遇到的问题是,如果在遍历队
有人可以解释一下主要区别吗?我对任何语言的编程中的这些功能都没有清楚的了解。 最佳答案 C 和 C++ 等编程语言中的一些基本数据结构是堆栈和队列。 堆栈数据结构遵循“先进后出”策略 (FILO),其
private Queue _queueObject = new Queue(); private static Queue _queueItem = new Queue(); private sta
我在CircularArrayQueue类中遇到了enqueue()方法: public void enqueue (T element) { if (size() == queue.length){
我是一名优秀的程序员,十分优秀!