excel队列

时间:2023-04-21 08:58:40 

队列的工作原理很简单,因为它与现实生活中的队列完全相同。例如,你在食堂窗口排队打饭,如果你先到,当然该你先打饭,我排在你的后面,则在你打完饭后我再打饭。

队列只有两种操作:入队和出队。将一个元素加入队列,称为入队;从队列中取出一个元素,称为出队,如下图1所示。

excel队列

图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所示。

excel队列

图2

然后,进行连接,如下图3所示。

excel队列

图3

如果添加新元素前为空队列,则将队首和队尾均指向新元素,如下图4所示。

excel队列

图4

在移除元素时,从队首开始,如下图5所示。原先qFront指向甲,现在将其指向乙。

excel队列

图5

Queue类模块代码的图片版如下:

excel队列

示例

下面的示例简单演示了队列。代码首先生成一个队列并将“甲已丙丁”依次添加到该队列,然后移除队列中的元素。

‘创建新队列

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所示。可以看到,出队的顺序与入队的顺序相同。

excel队列

图6

标签:excel图表制作,excel常用函数,excel数据透视表,Excel教程
0
投稿

猜你喜欢

  • excel表格怎么做一元线性回归分析图表?

    2022-12-03 03:09:55
  • Excel怎样实现隔多列数据求和

    2023-12-07 12:43:24
  • Win10系统如何清空粘贴板?Win10清空粘贴板的方法

    2023-08-01 15:07:38
  • Excel如何对不连续的单元格填充相同值

    2023-09-30 08:34:45
  • word中如何制作文字双行合一

    2022-05-26 21:48:49
  • Project怎么把工作日改为天? project工作日改为days的教程

    2023-07-15 01:52:14
  • 在excel表格中怎么使用REPLACEB函数?

    2023-02-16 00:44:49
  • 如何在Mac的Word 2011中制作表格?

    2022-03-31 02:26:42
  • Word2003打不开怎么办?

    2023-12-13 21:36:40
  • 如何将word文档转换为jpg格式

    2023-09-06 20:31:25
  • 原版win10安装教程_原版win10要怎么安装?

    2023-11-11 08:36:21
  • Word如何制作饼图图表?Word饼形图表制作过程

    2023-08-26 14:14:24
  • excel中一个单元格的数据怎么分列成多个数据?

    2023-03-16 14:27:54
  • Win10系统扩展C盘仍然是灰色怎么办?

    2023-11-23 18:44:53
  • Win10更新失败出现错误0x8024000b完美解决方法

    2023-12-13 07:41:44
  • Win10专业版更新失败怎么解决?Win10专业版更新失败解决方法

    2023-11-14 15:10:06
  • Word2010页面背景的修改设置

    2023-12-13 06:21:50
  • 怎样使用office帮助?

    2023-10-28 14:54:12
  • word页面设置在哪里设置

    2022-07-22 11:20:08
  • Excel表格中自动添加的超连接怎么取消?

    2022-07-26 00:33:25
  • asp之家 电脑教程 m.aspxhome.com