excel队列
发布时间:2023-04-21 08:58:40
队列的工作原理很简单,因为它与现实生活中的队列完全相同。例如,你在食堂窗口排队打饭,如果你先到,当然该你先打饭,我排在你的后面,则在你打完饭后我再打饭。
队列只有两种操作:入队和出队。将一个元素加入队列,称为入队;从队列中取出一个元素,称为出队,如下图1所示。
图1
根据队列的工作原理,在图1所示的队列中,丁只能加到队列的末尾,而排在最前的甲将最先出队。
下面,我们使用VBA代码实现队列。
实现队列结构需要两个类模块:QueueItem类模块和Queue类模块。
QueueItem类模块
在QueueItem类模块中,存放着一个数据值和一个指向下一个元素的指针。代码如下:
‘下一个队列元素
Public NextItem As QueueItem
‘队列中当前元素的值
Public Value As Variant
Queue类模块
在Queue类模块中,包含两个方法和一个属性。其中,Add方法在队列中添加元素,即执行入队操作;Remove方法移除队列中的元素,即执行出队操作;QueueEmpty属性判断队列是否为空。完整的代码如下:
‘指向队列列首的指针
Dim qFront As QueueItem
‘指向队列列尾的指针
Dim qRear As QueueItem
‘入队
Public Sub Add(varNewItem AsVariant)
‘声明并创建新元素
Dim qNew As New QueueItem
‘将值赋给新元素
qNew.Value = varNewItem
‘如果队列为空,则前后指针都指向新元素
If QueueEmpty Then
Set qFront = qNew
Set qRear = qNew
Else
‘将最后的元素指针指向新元素
Set qRear.NextItem = qNew
‘将指向队列列尾的指向新元素
Set qRear = qNew
End If
End Sub
‘出队
‘移除队列列首的元素并返回其值
Public Function Remove() AsVariant
‘如果队列为空,则返回空
If QueueEmpty Then
Remove = Null
Else
‘获取队列列首元素值
Remove = qFront.Value
‘如果队列中仅一个元素
‘则移除后队列为空
If qFront Is qRear Then
Set qFront = Nothing
Set qRear = Nothing
Else
Set qFront = qFront.NextItem
End If
EndIf
End Function
‘判断队列是否为空
Property Get QueueEmpty() AsBoolean
‘如果队列为空则返回True
QueueEmpty = ((qFront Is Nothing) And(qRear Is Nothing))
End Property
假设原有队列“甲乙丙”,现在要将“丁”加入该队列。在Add方法中,首先生成新节点并赋值,如下图2所示。
图2
然后,进行连接,如下图3所示。
图3
如果添加新元素前为空队列,则将队首和队尾均指向新元素,如下图4所示。
图4
在移除元素时,从队首开始,如下图5所示。原先qFront指向甲,现在将其指向乙。
图5
Queue类模块代码的图片版如下:
示例
下面的示例简单演示了队列。代码首先生成一个队列并将“甲已丙丁”依次添加到该队列,然后移除队列中的元素。
‘创建新队列
Dim qTest As New Queue
Sub testQueue()
With qTest
‘入队
.Add “甲”
.Add “乙”
.Add “丙”
.Add “丁”
Debug.Print “出队顺序:”
‘出队
Do While Not .QueueEmpty
Debug.Print .Remove()
Loop
End With
End Sub
运行后的结果如下图6所示。可以看到,出队的顺序与入队的顺序相同。
图6


猜你喜欢
- 创世写作是一款专门为网上写作者量身定做的写作软件,我们在完成一篇小说还是文章的时候,首先要进行的是保存,那你知道创世写作怎么保存的吗?接下来
- PS是我们最常用的修图工具,我们可以使用PS制作出许多精美的照片,当中有许多入门的小技巧,很多用户还没全部学会,今天就给大家带来一篇PS的入
- AE视图与锚点如何同时居中?最近很多小伙伴问如果想在Ae中实现视图与锚点同时居中,应该怎么操作呢?今天小编就给大家带来Ae锚点与视图同时居中
- 如果打开的表格,里面的内容刚好是你要创建的文件夹名称的话,那么你还要创建吗?批量创建指定名字的文件夹,很方便,很实用。那么excel如何批量
- Excel的内置工作表函数名总是使用大写字母,如下图1所示。即便在输入函数时使用的是小写字母,输入完成后,Excel会自动将其转换成大写字母
- 酷狗乐库是一款作为大部分网民听音乐首选的音乐软件之一,然而最近有很多Windows 7系统用户表示遇到了酷狗乐库加载不出来音乐的故障,对自己
- 电脑的物理地址就是网卡的物理地址,一般物理地址在网卡中是固定的,有win7系统用户换了电脑发现上不了网,因此就想到怎么修改物理地址,但由于不
- 现在人们越来越注重自己的隐私,而Mac电脑中的便签程序在日常应用中有很多个人隐私的东西,因此我们要学会给Mac便签程序上把“锁”。下面分享如
- Edge浏览器打开自动跳转到反诈中心网页怎么办?Edge浏览器是微软自带的电脑浏览器。有用户在使用这个浏览器的时候,发现打开的时候,会自动跳
- compaq-rba.exe是康柏Compaq电脑消息服务程序。用于康柏电脑使用反馈进程文件: compaq-rba or compaq-r
- 平时在使用电脑的过程当中经常都会遇到各种各样的问题,就不如“win缓存文件写入失败”这个问题就是是我们大家在使用电脑时,都有可能还有遇到的一
- 相信大部分用户在使用wps软件时可以感受到很不错的功能服务,当用户在线编辑文件时,只需要在掌握使用方法的基础上就可以找到对应的功能设置自己的
- 在微软系统中,窗口界面都是能够实现自动贴边的,这样不仅可以有效的提高我们的工作效率,还可以更好的利用屏幕空闲桌面,但有小伙伴在使用的时候却无
- Win8笔记本通过外接线连接到一台显示器上面后,外接显示器出现了花屏现象,有时是黑屏,而笔记本则没事,关于这个问题的解决方法如下此前有网友表
- 使用PowerPoint2013制作好了一份漂亮的PPT幻灯片档,现在想把它转换成一张张的图片,因为这些幻灯片档只能在PowerPoint2
- 很多人想知道自家电脑升级win10系统需要满足什么条件,虽然早前媒体也有报道过win10电脑配置需求,最终的win10硬件配置要求在昨日被微
- Excel状态栏位于程序窗口底部,它可以显示各种状态信息,如单元格模式、功能键的开关状态等,Excel 2007的状态栏所包含的信息比Exc
- 方法一最简单的方法:建立一个空白文档,依次点击"插入"、"文件",找到受保护的文档,插入即可方法二在
- 聊到Word长文档排版,想起前不久一位学员述的一段过往经历,领导发来一份商业计划书,要求对文档进行排版美化,再加个目录和封面。老板一句简单的
- PPT怎么使用SmartArt排版图片?PPT中想要排版图形,需要使用SmartArt,该怎么使用呢?下面我们就来看看详细的教程,需要的朋友