亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來(lái)到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? comp_reducerdyneliasgamma.bas

?? 網(wǎng)上收集的多種加密解密以及壓縮算法vb源碼。
?? BAS
字號(hào):
Attribute VB_Name = "Comp_ReducerDynEliasGamma"


Option Explicit

'This is a 1 run method but we have to keep the whole contents
'in memory until some variables are saved wich are needed bij the decompressor

Private Type BytePos
    Data() As Byte
    Position As Long
    Buffer As Integer
    BitPos As Integer
End Type
Private Stream(1) As BytePos    '0=control 1=BitStreams

Private CharCount(256) As Long

Private Dictionary As String
Private BitsForHeader As Integer   '1=max 6 chars  2=max 30 chars  3=more then 30 chars
Private LeadingZero(9) As Integer
Private GammaCode(9) As Integer
Private BitsToFollow(9) As Integer

Public Sub Compress_ReducerDynamicEG(ByteArray() As Byte)
    Dim X As Long
    Dim Y As Long
    Dim NoMore As Boolean
    Dim Most As Long
    Dim NewFileLen As Long
    Dim Nuchar As Byte
    Dim CharCount(255) As Long
    Call Init_ReducerDynamicEG
'whe only read the stream and convert them to bitstreams
    For X = 0 To UBound(ByteArray)
        Call AddValueToStream(CInt(ByteArray(X)))
    Next
'send the EOF-marker
    Call AddValueToStream(256)
'lets fill the leftovers
    For X = 0 To 1
        Do While Stream(X).BitPos > 0
            Call AddBitsToStream(Stream(X), 0, 1)
        Loop
    Next
'Lets restore the bounderies
    For X = 0 To 1
        ReDim Preserve Stream(X).Data(Stream(X).Position - 1)
    Next
'whe calculate the new length of the new data
    NewFileLen = 0
    For X = 0 To 1
        NewFileLen = NewFileLen + UBound(Stream(X).Data) + 1
    Next
    ReDim ByteArray(NewFileLen + 3)
'here we store the compressed data
    NewFileLen = 0
    For X = 0 To 0
        ByteArray(NewFileLen) = Int(UBound(Stream(X).Data) / &H10000) And &HFF
        NewFileLen = NewFileLen + 1
        ByteArray(NewFileLen) = Int(UBound(Stream(X).Data) / &H100) And &HFF
        NewFileLen = NewFileLen + 1
        ByteArray(NewFileLen) = UBound(Stream(X).Data) And &HFF
        NewFileLen = NewFileLen + 1
    Next
    For X = 0 To 1
        For Y = 0 To UBound(Stream(X).Data)
            ByteArray(NewFileLen) = Stream(X).Data(Y)
            NewFileLen = NewFileLen + 1
        Next
    Next
End Sub

Public Sub DeCompress_ReducerDynamicEG(ByteArray() As Byte)
    Dim OutStream() As Byte
    Dim OutPos As Long
    Dim InposCont As Long
    Dim InContBit As Integer
    Dim InposData As Long
    Dim InDataBit As Integer
    Dim Char As Integer
    Dim Numbits As Integer
    Dim X As Long
    Dim Temp As Integer
    Dim bitcount As Integer
    ReDim OutStream(500)
    Call Init_ReducerDynamicEG
    InposCont = 0
    InposData = 0
    For X = 0 To 2
        InposData = CLng(InposData) * 256 + ByteArray(InposCont)
        InposCont = InposCont + 1
    Next
    InposData = InposData + InposCont + 1
    InContBit = 0
    InDataBit = 0
    OutPos = 0
    Do
        bitcount = 0
        Do While ReadBitsFromArray(ByteArray, InposCont, InContBit, 1) = 0 And bitcount < 9
            bitcount = bitcount + 1
        Loop
'        If bitcount = 9 Then ReadEliasCode = 256: Exit Function
        Temp = 2 ^ bitcount
        If bitcount < 8 Then
            Temp = Temp + ReadBitsFromArray(ByteArray, InposCont, InContBit, bitcount)
        End If
        Numbits = Temp
'        Numbits = ReadBitsFromArray(ByteArray, InposCont, InContBit, BitsForHeader) + 1
        Char = ReadBitsFromArray(ByteArray, InposData, InDataBit, Numbits)
        Char = ExpanderBits(Numbits, Char)
        If Char = 256 Then Exit Do
        Call AddCharToArray(OutStream, OutPos, CByte(Char))
    Loop
    ReDim ByteArray(OutPos - 1)
    For X = 0 To OutPos - 1
        ByteArray(X) = OutStream(X)
    Next
End Sub

Private Sub Init_ReducerDynamicEG()
    Dim X As Integer
    Dictionary = ""
    For X = 0 To 255
        Dictionary = Dictionary & Chr(X)
        CharCount(X) = 0
    Next
    CharCount(256) = 0
    BitsForHeader = 3
    For X = 0 To 1
        ReDim Stream(X).Data(500)
        Stream(X).BitPos = 0
        Stream(X).Buffer = 0
        Stream(X).Position = 0
    Next
    LeadingZero(0) = 0: GammaCode(0) = 1: BitsToFollow(0) = 0    '1                  =1         -7
    LeadingZero(1) = 1: GammaCode(1) = 1: BitsToFollow(1) = 1    '01x                =2-3       -5
    LeadingZero(2) = 2: GammaCode(2) = 1: BitsToFollow(2) = 2    '001xx              =4-7       -3
    LeadingZero(3) = 3: GammaCode(3) = 1: BitsToFollow(3) = 3    '0001xxx            =8-15      -1
    LeadingZero(4) = 4: GammaCode(4) = 1: BitsToFollow(4) = 4    '00001xxxx          =16-31     +1
    LeadingZero(5) = 5: GammaCode(5) = 1: BitsToFollow(5) = 5    '000001xxxxx        =32-63     +3
    LeadingZero(6) = 6: GammaCode(6) = 1: BitsToFollow(6) = 6    '0000001xxxxxx      =64-127    +5
    LeadingZero(7) = 7: GammaCode(7) = 1: BitsToFollow(7) = 7    '00000001xxxxxxx    =128-255   +7
    LeadingZero(8) = 8: GammaCode(7) = 1: BitsToFollow(8) = 0    '000000001          =256       +1
    LeadingZero(9) = 8: GammaCode(9) = 0: BitsToFollow(8) = 0    '000000000          =257       +1   EOF
End Sub

Private Function ReducerBits(Char As Integer) As Integer
    Dim DiPos As Integer
    Dim TotPos As Integer
    Dim Y As Integer
    If Char = 256 Then ReducerBits = 8: Char = 255: Exit Function
    DiPos = InStr(Dictionary, Chr(Char)) - 1
    Call update_Model(Char)
    For Y = 1 To 8
        If DiPos >= TotPos And DiPos < TotPos + 2 ^ Y Then
            ReducerBits = Y
            Char = DiPos - TotPos
            Exit Function
        End If
        TotPos = TotPos + 2 ^ Y
    Next
End Function

Private Function ExpanderBits(BitsNum As Integer, BytePos As Integer) As Integer
    If BitsNum = 8 And BytePos = 255 Then ExpanderBits = 256: Exit Function
    Dim TotPos As Integer
    Dim Y As Integer
    For Y = 1 To BitsNum - 1
        TotPos = TotPos + 2 ^ Y
    Next
    TotPos = TotPos + BytePos + 1
    ExpanderBits = ASC(Mid(Dictionary, TotPos, 1))
    Call update_Model(ExpanderBits)
End Function

Private Sub update_Model(Char As Integer)
    Dim DictPos As Integer
    Dim OldPos As Integer
    Dim Temp As Long
    DictPos = InStr(Dictionary, Chr(Char))
    OldPos = DictPos
    CharCount(DictPos) = CharCount(DictPos) + 1
    Do While DictPos > 1 And CharCount(DictPos) >= CharCount(DictPos - 1)
        Temp = CharCount(DictPos - 1)
        CharCount(DictPos - 1) = CharCount(DictPos)
        CharCount(DictPos) = Temp
        DictPos = DictPos - 1
    Loop
    If OldPos = DictPos Then Exit Sub
    Dictionary = Left(Dictionary, DictPos - 1) & Chr(Char) & Mid(Dictionary, DictPos, OldPos - DictPos) & Mid(Dictionary, OldPos + 1)
End Sub

Private Sub AddValueToStream(Number As Integer)
    Dim BitsDeep As Integer
    Dim Code As Integer
    BitsDeep = ReducerBits(Number)
    Code = Get_Elias_Code(BitsDeep)
    Call AddBitsToStream(Stream(0), 0, LeadingZero(Code))
    Call AddBitsToStream(Stream(0), CLng(GammaCode(Code)), 1)
    Call AddBitsToStream(Stream(0), BitsDeep, BitsToFollow(Code))
'    Call AddBitsToStream(Stream(0), BitsDeep - 1, BitsForHeader)
    Call AddBitsToStream(Stream(1), Number, BitsDeep)
End Sub

'this sub will add an amount of bits to a sertain stream
Private Sub AddBitsToStream(Toarray As BytePos, Number As Integer, Numbits As Integer)
    Dim X As Long
    If Numbits = 8 And Toarray.BitPos = 0 Then
        If Toarray.Position > UBound(Toarray.Data) Then ReDim Preserve Toarray.Data(Toarray.Position + 500)
        Toarray.Data(Toarray.Position) = Number And &HFF
        Toarray.Position = Toarray.Position + 1
        Exit Sub
    End If
    For X = Numbits - 1 To 0 Step -1
        Toarray.Buffer = Toarray.Buffer * 2 + (-1 * ((Number And 2 ^ X) > 0))
        Toarray.BitPos = Toarray.BitPos + 1
        If Toarray.BitPos = 8 Then
            If Toarray.Position > UBound(Toarray.Data) Then ReDim Preserve Toarray.Data(Toarray.Position + 500)
            Toarray.Data(Toarray.Position) = Toarray.Buffer
            Toarray.BitPos = 0
            Toarray.Buffer = 0
            Toarray.Position = Toarray.Position + 1
        End If
    Next
End Sub

'this function will return a value out of the amaunt of bits you asked for
Private Function ReadBitsFromArray(FromArray() As Byte, FromPos As Long, FromBit As Integer, Numbits As Integer) As Long
    Dim X As Integer
    Dim Temp As Long
    For X = 1 To Numbits
        Temp = Temp * 2 + (-1 * ((FromArray(FromPos) And 2 ^ (7 - FromBit)) > 0))
        FromBit = FromBit + 1
        If FromBit = 8 Then
            If FromPos + 1 > UBound(FromArray) Then
                Do While X < Numbits
                    Temp = Temp * 2
                    X = X + 1
                Loop
                FromPos = FromPos + 1
                Exit For
            End If
            FromPos = FromPos + 1
            FromBit = 0
        End If
    Next
    ReadBitsFromArray = Temp
End Function

'this sub will add a char into the outputstream
Private Sub AddCharToArray(Toarray() As Byte, ToPos As Long, Char As Byte)
    If ToPos > UBound(Toarray) Then ReDim Preserve Toarray(ToPos + 500)
    Toarray(ToPos) = Char
    ToPos = ToPos + 1
End Sub

Private Function Get_Elias_Code(Number As Integer) As Integer
    Select Case Number
    Case 1
        Get_Elias_Code = 0
    Case Is < 4
        Get_Elias_Code = 1
    Case Is < 8
        Get_Elias_Code = 2
    Case Is < 16
        Get_Elias_Code = 3
    Case Is < 32
        Get_Elias_Code = 4
    Case Is < 64
        Get_Elias_Code = 5
    Case Is < 128
        Get_Elias_Code = 6
    Case Is < 256
        Get_Elias_Code = 7
    Case Is = 256
        Get_Elias_Code = 8
    Case Else
        Get_Elias_Code = 9
    End Select
End Function

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91精品国产欧美一区二区成人 | www精品美女久久久tv| 国产成人午夜精品影院观看视频| 亚洲欧美另类久久久精品| 欧美一级一级性生活免费录像| 成人一区二区三区| 日本最新不卡在线| 亚洲男人的天堂网| 久久久91精品国产一区二区精品| 在线精品国精品国产尤物884a | 欧美网站一区二区| 国产成人精品www牛牛影视| 日韩在线a电影| 依依成人综合视频| 国产精品久久99| 久久男人中文字幕资源站| 69精品人人人人| 欧美系列日韩一区| 97久久精品人人做人人爽50路| 国产在线一区观看| 日韩中文字幕不卡| 一二三区精品福利视频| 中文字幕精品一区二区三区精品 | 久久一夜天堂av一区二区三区| 欧美调教femdomvk| 一本一道久久a久久精品| 国产成人免费视频一区| 国产原创一区二区三区| 免费成人你懂的| 青青国产91久久久久久| 午夜激情综合网| 伊人性伊人情综合网| 最新国产精品久久精品| 欧美国产日韩在线观看| 国产清纯白嫩初高生在线观看91 | 日本一区二区动态图| 久久久久久久久99精品| 精品成人佐山爱一区二区| 日韩区在线观看| 欧美成人乱码一区二区三区| 欧美一区二区大片| 精品国产1区2区3区| 精品久久久久久久久久久院品网| 日韩欧美一卡二卡| 精品国精品国产| 久久美女高清视频 | 同产精品九九九| 亚洲成人免费在线观看| 五月天激情综合网| 免费在线观看不卡| 国产精品一色哟哟哟| 国产69精品久久久久777| 豆国产96在线|亚洲| 99精品国产热久久91蜜凸| 色女孩综合影院| 欧美日韩国产系列| 欧美一区二区啪啪| 久久久www成人免费毛片麻豆 | 欧美另类videos死尸| 日韩一区二区精品在线观看| 欧美成人三级在线| 国产精品美女久久久久久久久久久 | 国产精品资源在线观看| 成人丝袜视频网| 91久久精品一区二区三| 91精品国产综合久久久久久| 偷拍自拍另类欧美| 日本不卡视频在线观看| 国产精品一区二区你懂的| 99国产精品国产精品毛片| 在线观看不卡一区| 精品久久久久久久久久久久久久久久久| 国产欧美一区二区三区在线看蜜臀| 中文字幕一区三区| 青青草原综合久久大伊人精品| 国内精品久久久久影院薰衣草| thepron国产精品| 欧美日韩精品欧美日韩精品一 | 亚洲日本一区二区| 秋霞午夜鲁丝一区二区老狼| 懂色av一区二区三区免费看| 欧美亚洲高清一区二区三区不卡| 日韩欧美色综合网站| 综合在线观看色| 另类综合日韩欧美亚洲| 波多野结衣中文字幕一区二区三区| 欧美色图片你懂的| 国产午夜三级一区二区三| 亚洲午夜久久久久久久久久久| 久久精品国产一区二区| 91麻豆精品视频| 精品国产人成亚洲区| 亚洲精品亚洲人成人网在线播放| 久久精工是国产品牌吗| 色香色香欲天天天影视综合网| 精品美女一区二区| 一区二区三区精密机械公司| 国产一区二区伦理片| 欧美人与禽zozo性伦| 亚洲国产成人在线| 美国毛片一区二区| 欧美在线观看你懂的| 中日韩免费视频中文字幕| 男男视频亚洲欧美| 日本电影亚洲天堂一区| 亚洲国产精品v| 久久99久久久久久久久久久| 欧美视频在线一区| 中文字幕一区二区三区精华液 | 久久久久综合网| 日韩电影在线一区二区三区| 色婷婷国产精品综合在线观看| 久久午夜国产精品| 日本少妇一区二区| 欧美日韩一区二区三区在线 | 亚洲精品在线免费观看视频| 亚洲国产成人高清精品| 91丝袜高跟美女视频| 国产肉丝袜一区二区| 精品一区二区三区的国产在线播放 | 日韩欧美国产综合一区| 婷婷综合在线观看| 欧美日韩综合在线| 一区二区三区四区亚洲| 91视视频在线观看入口直接观看www| 久久亚区不卡日本| 激情综合色综合久久| 欧美一区二区女人| 另类成人小视频在线| 欧美一区二区人人喊爽| 蜜臀国产一区二区三区在线播放| 欧美日韩一本到| 亚洲国产毛片aaaaa无费看| 色伊人久久综合中文字幕| 欧美精品一区二区三区蜜桃视频| 美日韩一级片在线观看| 91精品国产综合久久久久久久久久 | 日韩欧美另类在线| 乱一区二区av| 久久先锋影音av| 顶级嫩模精品视频在线看| 中文无字幕一区二区三区| 国产99一区视频免费| 中文在线一区二区| 91原创在线视频| 亚洲综合一区二区三区| 欧美日韩国产一级二级| 免费在线观看视频一区| 欧美精品一区二区蜜臀亚洲| 国产精品99精品久久免费| 欧美激情在线一区二区三区| 成人黄色小视频| 亚洲另类春色国产| 欧美日韩黄色一区二区| 久久精品国产免费看久久精品| 久久青草国产手机看片福利盒子| 国产伦精品一区二区三区免费| 欧美国产激情一区二区三区蜜月| 不卡高清视频专区| 亚洲最大成人综合| 日韩一区二区三区三四区视频在线观看| 精品一区二区三区在线视频| 国产午夜精品福利| 中文字幕av不卡| 欧美三级日韩三级国产三级| 免费高清在线一区| 久久久久久久久一| 91国产精品成人| 老司机精品视频在线| 中文av字幕一区| 欧美美女激情18p| 国产成人丝袜美腿| 亚洲在线观看免费| 精品国产乱码久久久久久牛牛| 成人爱爱电影网址| 午夜欧美2019年伦理| www久久久久| 91久久精品网| 国产一区二区三区四| 一区二区三区高清不卡| 欧美精品一区二区三区在线播放| 国产盗摄一区二区| 婷婷中文字幕综合| 国产精品毛片高清在线完整版| 欧美日韩在线播放| 成人高清视频在线| 日韩电影在线观看电影| 中文字幕精品综合| 日韩一区二区三区视频在线观看| 97久久久精品综合88久久| 经典三级一区二区| 一区二区三区久久| 国产日韩欧美不卡在线| 欧美日韩不卡在线| av在线这里只有精品| 精久久久久久久久久久| 香蕉加勒比综合久久| 国产精品久久精品日日| 精品成人在线观看| 欧美日韩久久久久久|