用二分法查找第一个断码的数字-Aaron
Access软件网QQ交流学习群(群号码198465573),欢迎您的加入!
首页 >技术文章> Access数据库-模块/函数/VBA


用二分法查找第一个断码的数字

发表时间:2013/12/12 22:39:44 评论(0) 浏览(4062)  评论 | 加入收藏 | 复制
   
摘 要:对于一系列没有重复的数字,用二分法查出最小的一个断码数字。
正 文:

对于一系列没有重复的数字,用二分法查出最小的一个断码数字。

对于上千万条记录,几十毫秒就搞定了。

自己扩展到带前缀的编号补充断码去吧:)


Time=t*log(Nmax,2)

Time:总时间

t:一次迭代的时间

Nmax:记录最大的数字

log(Nmax,2):以2为底,Nmax的对数



'//*******************************************************************

'//函数调用

Me.txtResult = Me.txtResult & ReplenishTable("表3", "ID") & vbCrLf

'//*******************************************************************

Public Function ReplenishTable(TableName As String, FieldName As String) As Long
    Dim lngStart As Long
    Dim lngMax As Long
    On Error GoTo ErrorHandler
    If DCount(FieldName, TableName) = 0 Then
        ReplenishTable = 1
        GoTo ExitHere
    End If
    lngMax = DMax(FieldName, TableName)
    ReplenishTable = LossNumber(TableName, FieldName, 1, lngMax)
ExitHere:
    Exit Function
ErrorHandler:
    ReplenishTable = -1
    MsgBox Err.Number & Err.Description
    Resume ExitHere
End Function

Public Function LossNumber(TableName As String, _
                             FieldName As String, _
                             Optional StartNumber As Long = -1, _
                             Optional EndNumber As Long = -1, _
                             Optional LastEnd As Long = -1 _
                             ) As Long

    Dim lngCountRecords As Long
    Dim lngCalRecords As Long
    Dim lngNextStart As Long, lngNextEnd As Long, lngNextLast As Long
   
    If StartNumber = -1 Then StartNumber = 1
   
    lngCountRecords = CountRecords(TableName, FieldName, StartNumber, EndNumber)
    lngCalRecords = CalRecords(StartNumber, EndNumber)
    If lngCountRecords > 0 Then
        If lngCountRecords = lngCalRecords Then
            If LastEnd = -1 Then
                MsgBox "No Loss"
                Exit Function
            Else
                '//后半区间
                lngNextStart = EndNumber + 1
                lngNextEnd = LastEnd
                lngNextLast = LastEnd
            End If
        Else
            '//前半区间
            lngNextStart = StartNumber
            lngNextEnd = CLng((EndNumber - StartNumber) / 2) + StartNumber
            lngNextLast = EndNumber
        End If
        LossNumber = LossNumber(TableName, FieldName, lngNextStart, lngNextEnd, lngNextLast)
    Else
        LossNumber = StartNumber
    End If
End Function

Public Function CountRecords(TableName As String, FieldName As String, StartNumber As Long, EndNumber As Long) As Long
    Dim lngTotalRecords As Long
    CountRecords = DCount(FieldName, TableName, FieldName & " >= " & StartNumber & " AND " & FieldName & "<=" & EndNumber)
End Function

Public Function CalRecords(StartNumber As Long, EndNumber As Long) As Long
    CalRecords = EndNumber - StartNumber + 1
End Function


Access软件网交流QQ群(群号:198465573)
 
 相关文章
自定义自动编号,支持断号重号检测补号功能  【andymark  2008/4/2】
再谈自动编号函数AutoNum()可以检测断号...使断号重续.....  【chenlugen  2008/8/31】
自定义自动编号,带断号检测补号功能  【andymark  2008/11/6】
[access查询]一条语句查最小断号  【andymark  2010/4/8】
【access小品】断号列表函数  【煮江品茶  2011/4/23】
[access查询]【access技巧】最小断号查找的最高效方法(...  【红尘如烟  2012/5/22】
断号重续之我见  【LiShiping  2012/8/18】
查ID号的断号  【蒋元根  2013/5/24】
常见问答
技术分类
相关资源
文章搜索
关于作者

Aaron

文章分类

文章存档

友情链接