vb6.0的链表

   2023-02-09 学习力0
核心提示:vb6.0过时了吗?是的,应该是。不过,到现在,它仍然有它的不可替代的用途。起码,.net开发的程序还不是每个电脑都能够运行,起码,现在的vb.net已经不支持ole控件。新的有新的理由,用旧的也有旧的用途。从这个角度看,所有的技术都谈不上过时与不过时。我现

vb6.0过时了吗?是的,应该是。不过,到现在,它仍然有它的不可替代的用途。起码,.net开发的程序还不是每个电脑都能够运行,起码,现在的vb.net已经不支持ole控件。新的有新的理由,用旧的也有旧的用途。从这个角度看,所有的技术都谈不上过时与不过时。

我现在在做的题库,比较起来就用vb6.0开发要方便得多。只不过原来习惯于C++的STL,突然发现原来VB6.0连内建的链表都没有。没办法,只能自己建造***了。现在把我自己写的这个链表与大家分享,或许你也需要,或许,你觉得我的这个设计笨拙得有些要命,那就请你帮我提出修改意见,不胜感谢。

先定义数据节点(定义一个叫ListNode的类),从性能角度考虑,定义出具体的数据类型,此处为String,可改为其他类型:

 ListNode 

再 定义一个双向链表类(StrList)


Size = mvarSize
End Function

Public Function IsEnd() As Boolean
IsEnd 
= curNode Is Nothing
End Function

Public Function IsHead() As Boolean
IsHead 
= curNode Is mvarHead
End Function
Public Sub Unique()
Dim bDelete As Boolean
Dim temNode As ListNode
Dim strValue As String
GoHead
Do While Not IsEnd
strValue 
= GetValue
Set temNode = curNode
GoNext
    
Do While Not IsEnd
        bDelete 
= True
        
If GetValue = strValue Then
        
If temNode Is endNode Then
            
Exit Sub
        
ElseIf curNode Is endNode Then
            
Set endNode = curNode.preNode
            
Set endNode.nextNode = Nothing
            
Set curNode = endNode
        
Else
            
Set curNode.preNode.nextNode = curNode.nextNode
            
Set curNode.nextNode.preNode = curNode.preNode
            
Set curNode = curNode.nextNode
        
End If
        mvarSize 
= mvarSize - 1
        bDelete 
= False
        
End If
        
If (Not IsEnd) And bDelete Then GoNext
    
Loop
    
Set curNode = temNode.nextNode
Loop
End Sub

Public Sub ReMove(strValue As String)
Dim bDelete As Boolean
GoHead
Do While Not IsEnd
bDelete 
= True
    
If GetValue = strValue Then
    
If mvarHead Is endNode Then
        
Set mvarHead = Nothing
        
Set endNode = Nothing
        
Set curNode = Nothing
    
ElseIf curNode Is mvarHead Then
        
Set mvarHead = curNode.nextNode
        
Set mvarHead.preNode = Nothing
        
Set curNode = mvarHead
    
ElseIf curNode Is endNode Then
        
Set endNode = curNode.preNode
        
Set endNode.nextNode = Nothing
        
Set curNode = endNode
    
Else
        
Set curNode.preNode.nextNode = curNode.nextNode
        
Set curNode.nextNode.preNode = curNode.preNode
        
Set curNode = curNode.nextNode
    
End If
    mvarSize 
= mvarSize - 1
    bDelete 
= False
    
End If
    
If (Not IsEnd) And bDelete Then GoNext
Loop
End Sub
Public Sub Delete()
    
If mvarHead Is endNode Then
        
Set mvarHead = Nothing
        
Set endNode = Nothing
        
Set curNode = Nothing
    
ElseIf curNode Is mvarHead Then
        
Set mvarHead = curNode.nextNode
        
Set mvarHead.preNode = Nothing
        
Set curNode = mvarHead
    
ElseIf curNode Is endNode Then
        
Set endNode = curNode.preNode
        
Set endNode.nextNode = Nothing
        
Set curNode = endNode
    
Else
        
Set curNode.preNode.nextNode = curNode.nextNode
        
Set curNode.nextNode.preNode = curNode.preNode
        
Set curNode = curNode.nextNode
    
End If
    mvarSize 
= mvarSize - 1
End Sub

Public Sub Clear()
Set mvarHead = Nothing
Set endNode = Nothing
Set curNode = Nothing
mvarSize 
= 0
End Sub

Public Sub Add(strValue As String)
Dim node As New ListNode
node.strValue 
= strValue
Set node.preNode = endNode
If mvarHead Is Nothing Then
    
Set mvarHead = node
    
Set curNode = node
Else
    
Set endNode.nextNode = node
End If
Set endNode = node
 mvarSize 
= mvarSize + 1
End Sub

Public Sub GoNext()
Set curNode = curNode.nextNode
End Sub
Public Sub GoAhead()
Set curNode = curNode.preNode
End Sub
Public Function GetValue() As String
GetValue 
= curNode.strValue
End Function

Public Sub GoHead()
Set curNode = mvarHead
End Sub
Public Sub GoLast()
Set curNode = endNode
End Sub



利用这个双向链表构造一个循环链表(CycList):


Size = list.Size
End Function

Public Sub ReMove(strValue As String)
list.ReMove strValue
End Sub
Public Sub Delete()
list.Delete
End Sub
Public Sub Clear()
list.Clear
End Sub

Public Sub Add(strValue As String)
list.Add strValue
End Sub

Public Sub GoNext()
If list.IsEnd Then list.GoHead
list.GoNext
If list.IsEnd Then list.GoHead
End Sub

Public Sub GoAhead()
If list.IsEnd Then list.GoLast
list.GoAhead
If list.IsEnd Then list.GoLast
End Sub

Public Function GetValue() As String
GetValue 
= list.GetValue
End Function

Public Sub GoHead()
list.GoHead
End Sub

Public Function IsHead() As Boolean
IsHead 
= list.IsHead
End Function



使用实例代码: 

 StrList

list.Clear
list.Add "a"
list.Add 
"b"
 
list.GoHead
Do While Not list.IsEnd
     
'do something
     'list.GetValue 
list.GoNext

 



 

 

 
反对 0举报 0 评论 0
 

免责声明:本文仅代表作者个人观点,与乐学笔记(本网)无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
    本网站有部分内容均转载自其它媒体,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责,若因作品内容、知识产权、版权和其他问题,请及时提供相关证明等材料并与我们留言联系,本网站将在规定时间内给予删除等相关处理.

  • Windows API Reference for C#, VB.NET
    不错的.net 下用API的参考站点地址在:http://www.webtropy.com/articles/Win32-API-DllImport-art9.asp 下面摘抄分类,便于大家直接就拿来用: File, Memory, Process, Threading, Time, Console, and Comm control(kernel32.dll) _hread_hwrite_lclose_lcr
    03-16
  • 一个基于API的VB.net串口通讯类 vbnet串口通信
    VB.net的串口通讯支持总是让人觉得有所不足,在使用VB6的MsComm32.ocx时,很多人都会在VB.net的开发中觉得很困扰。    这里讲述的VB.net串口通讯类使用native代码,并且它是通API调用实现的,你会发现VB.net的串口通讯就是这么简单。    在说明如何使
    02-12
  • [VB][ASP.NET]FileUpload控件「批次上传 / 多档
    FileUpload控件「批次上传 / 多档案同时上传」的范例 (VB语法) http://www.dotblogs.com.tw/mis2000lab/archive/2008/05/14/3986.aspx    FileUpload控件真的简单好用,不使用它来作批次上传,却要改用别的方法,实在不聪明。要用就一次用到底,公开File
    02-10
  • 第八章 VB中ActiveX控件的使用
    轉自:http://wwww.hyit.edu.cn/edu/vb/study/index.htm第八章          VB中ActiveX控件的使用8.1  概述     这里的ActiveX控件是指VB标准工具箱里没有的控件,用时需从“工程”菜单里选择“部件…”(或右键单击工具箱,从快捷菜单中选择“部
    02-10
  • 第二章 VB的界面设计
    轉自:http://wwww.hyit.edu.cn/edu/vb/study/index.htm第二章         VB的界面设计2.1  VB用户界面设计基础1. 概述   界面的设计有两步:先绘制控件,然后确定控件属性。   绘制控件:在工具箱里单击想画的控件,在窗体里按下鼠标并拖曳,然后
    02-10
  • C#/VB.NET 获取Excel中图片所在的行、列坐标位置
    C#/VB.NET 获取Excel中图片所在的行、列坐标位
    本文以C#和vb.net代码示例展示如何来获取Excel工作表中图片的坐标位置。这里的坐标位置是指图片左上角顶点所在的单元格行和列位置,横坐标即顶点所在的第几列、纵坐标即顶点所在的第几行。下面是获取图片位置的详细方法及步骤。【程序环境】按照如下方法来引
    02-09
  • VB操作XML
    VB操作XML
    XSL(可扩展样式表语言)是对CSS的一种扩展,功能比CSS强大得多。XML链接是在HTML链接的功能之上加以扩展,可以支持更为复杂的链接,通过XML链接,不仅可以在XML文件之间建立链接,还可以建立其他类型数据之间的链接,其规范分为三个部分:XLink语言,XPointe
    02-09
  • VB6多线程,关键段操作 vb6.0 多线程
    Option Explicit Declare Function GetLastError Lib "kernel32" () As Long 'Declare Function CloseHandle Lib "kernel32" (ByVal hObject As Long) As Long 'Declare Sub ExitThread Lib "kernel32" (Optional ByVal dwExitCode
    02-09
  • VB.NET调用IE,并且等待
                Dim p As New Process            '获得URL            aURL = GetURL()            '获得IE路径            p.StartInfo.FileName = System.Environment.GetFolderPath( _ 
    02-09
  • vb的VSFlexGrid控件 vb msflexgrid
    多行选中VSFlexGrid的SelectionMode = flexSelectionListBox,现在可以配合Ctrl进行多行选择循环取值用vsflexgrid.SelectedRows 可以得到你选择的行的总数量然后用循环可以得到具体的行中具体列的内容Dim Temp  As StringDim i As IntegerFor i =
    02-09
点击排行