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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? comp_group64.bas

?? 網上收集的多種加密解密以及壓縮算法vb源碼。
?? BAS
字號:
Attribute VB_Name = "Comp_Group64"


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

'This is a grouping method
'it try to find follower bytes with a maximum range of 64
'if it found such a group it will subtract the lowest value
'and then store the lower 6 bits of the follower bytes
'in this way we can get a maximum compression of 25%
'This is excluded the header of the follower bytes
'this method works best after a move to front coder

Private OutPos As Long              'invoeg positie voor de output array
Private OutBitCount As Integer
Private OutByteBuf As Byte
Private ReadBitPos As Integer
Private NumExtBits(7) As Byte
  
Private Sub Init_Grouping()
    OutPos = 0
    OutBitCount = 0
    OutByteBuf = 0
    ReadBitPos = 0
    NumExtBits(0) = 3       '<8
    NumExtBits(1) = 3       '<16
    NumExtBits(2) = 4       '<32
    NumExtBits(3) = 5       '<64
    NumExtBits(4) = 6       '<128
    NumExtBits(5) = 7       '<256
    NumExtBits(6) = 8       '<512
    NumExtBits(7) = 16      ' de rest
End Sub

Public Sub Compress_Grouping(ByteArray() As Byte)
    Const MinBytes As Integer = 12  'minimum nuber of follower bytes needed to get compression
    Dim OutStream() As Byte         'The output array
    Dim BeginGroup As Long          'start positie of the groep
    Dim NumInGroup As Long
    Dim LowInGroup As Integer       'Lowest value in the groep
    Dim HighInGroup As Integer      'Highest value in the groep
    Dim Char As Integer
    Dim MaxDiff As Boolean
    Dim X As Long
    Dim Y As Long
    Dim TotFileLen As Long
    Dim NoCompress As Long
    Dim StartNocompress As Long
    TotFileLen = UBound(ByteArray)
    ReDim OutStream(TotFileLen + (TotFileLen / 7))  'in het slechtste geval
    BeginGroup = 0
    NumInGroup = 0
    Call Init_Grouping
    Do While BeginGroup + NumInGroup <= TotFileLen
        LowInGroup = ByteArray(BeginGroup + NumInGroup)
        HighInGroup = ByteArray(BeginGroup + NumInGroup)
        MaxDiff = False
        Do While MaxDiff = False
            NumInGroup = NumInGroup + 1
            If BeginGroup + NumInGroup > TotFileLen Then Exit Do
            Char = ByteArray(BeginGroup + NumInGroup)
            If Char < LowInGroup Then
                If HighInGroup - Char > 63 Then
                    MaxDiff = True
                Else
                    LowInGroup = Char
                End If
            ElseIf Char > HighInGroup Then
                If Char - LowInGroup > 63 Then
                    MaxDiff = True
                Else
                    HighInGroup = Char
                End If
            End If
        Loop
        NumInGroup = NumInGroup - 1
        If NumInGroup >= MinBytes Then               'we kunnen gaan splitten
            If NoCompress > 0 Then
'if we cant compress, store the header of the literal bytes
                Call AddGroupCodeToStream(OutStream, NoCompress, False)
'and store the literal bytes themself
                For X = StartNocompress To StartNocompress + NoCompress - 1
                    Call AddBitsToStream(OutStream, CLng(ByteArray(X)), 8)
                Next
                NoCompress = 0
            End If
'here whe're gone store the header of the compressed bytes
            Call AddGroupCodeToStream(OutStream, NumInGroup + 1, True)
'lets store the lowest value of the group
            Call AddBitsToStream(OutStream, CLng(LowInGroup), 8)
'and here whe're subtract the lowest value from the group and
'store bits 0 to 5 into the output stream
            For X = BeginGroup To BeginGroup + NumInGroup
                Call AddBitsToStream(OutStream, CLng(ByteArray(X) - LowInGroup), 6)
            Next
            BeginGroup = BeginGroup + NumInGroup + 1
        Else
            NoCompress = NoCompress + 1
            If NoCompress = 1 Then StartNocompress = BeginGroup 'Lets hold the pointer
            BeginGroup = BeginGroup + 1
        End If
        NumInGroup = 0
    Loop
'lets see if whe have had all the bytes
    If NoCompress > 0 Then
'if not, lets store the last bytes
        Call AddGroupCodeToStream(OutStream, NoCompress, False)
        For X = StartNocompress To StartNocompress + NoCompress - 1
            Call AddBitsToStream(OutStream, CLng(ByteArray(X)), 8)
        Next
        NoCompress = 0
    End If
'see if there are some bits leftover
    If OutBitCount < 8 Then
        Do While OutBitCount < 8
            OutByteBuf = OutByteBuf * 2
            OutBitCount = OutBitCount + 1
        Loop
        OutStream(OutPos) = OutByteBuf: OutPos = OutPos + 1
    End If
    OutPos = OutPos - 1
    ReDim ByteArray(OutPos + 4)
    ByteArray(0) = Int(TotFileLen / &H1000000) And &HFF
    ByteArray(1) = Int(TotFileLen / &H10000) And &HFF
    ByteArray(2) = Int(TotFileLen / &H100) And &HFF
    ByteArray(3) = TotFileLen And &HFF
    Call CopyMem(ByteArray(4), OutStream(0), OutPos + 1)
End Sub

Private Sub AddGroupCodeToStream(ToStream() As Byte, Number As Long, IsPacked As Boolean)
    Dim NumVal As Byte
    Dim X As Long
    OutByteBuf = OutByteBuf * 2 + (-1 * IsPacked)
    OutBitCount = OutBitCount + 1
    If OutBitCount = 8 Then: ToStream(OutPos) = OutByteBuf: OutBitCount = 0: OutByteBuf = 0: OutPos = OutPos + 1
    Select Case Number
    Case Is < 8
        NumVal = 0
    Case Is < 16
        NumVal = 1
    Case Is < 32
        NumVal = 2
    Case Is < 64
        NumVal = 3
    Case Is < 128
        NumVal = 4
    Case Is < 256
        NumVal = 5
    Case Is < 512
        NumVal = 6
    Case Else
        NumVal = 7
    End Select
'plaats 3 extra bits om de groote van het volgende getal aan te geven
    For X = 2 To 0 Step -1
        OutByteBuf = OutByteBuf * 2 + (-1 * ((NumVal And 2 ^ X) > 0))
        OutBitCount = OutBitCount + 1
        If OutBitCount = 8 Then: ToStream(OutPos) = OutByteBuf: OutBitCount = 0: OutByteBuf = 0: OutPos = OutPos + 1
    Next
'plaats het aantal nummer in de groep
    For X = NumExtBits(NumVal) - 1 To 0 Step -1
        OutByteBuf = OutByteBuf * 2 + (-1 * ((Number And 2 ^ X) > 0))
        OutBitCount = OutBitCount + 1
        If OutBitCount = 8 Then: ToStream(OutPos) = OutByteBuf: OutBitCount = 0: OutByteBuf = 0: OutPos = OutPos + 1
    Next
End Sub

Private Sub AddBitsToStream(ToStream() As Byte, Number As Long, Numbits As Integer)
    Dim X As Long
    For X = Numbits - 1 To 0 Step -1
        OutByteBuf = OutByteBuf * 2 + (-1 * ((Number And 2 ^ X) > 0))
        OutBitCount = OutBitCount + 1
        If OutBitCount = 8 Then: ToStream(OutPos) = OutByteBuf: OutBitCount = 0: OutByteBuf = 0: OutPos = OutPos + 1
    Next
End Sub

Public Sub DeCompress_Grouping(ByteArray() As Byte)
    Dim TotFileLen As Long
    Dim OutStream() As Byte         'The output array
    Dim InpPos As Long
    Dim NewPos As Long
    Dim PackedOrNot As Byte
    Dim NumBytes As Long
    Dim LowInGroup As Integer       'Lowest value in the group
    Dim NumVal As Byte
    Dim X As Integer
    For X = 0 To 3
        TotFileLen = CLng(TotFileLen) * 256
        TotFileLen = TotFileLen + ByteArray(X)
    Next
    ReDim OutStream(TotFileLen)
    InpPos = 4
    NewPos = 0
    Call Init_Grouping
    Do While NewPos < TotFileLen
        PackedOrNot = ReadBitsFromArray(ByteArray, InpPos, 1)
        NumVal = ReadBitsFromArray(ByteArray, InpPos, 3)
        NumBytes = ReadBitsFromArray(ByteArray, InpPos, CInt(NumExtBits(NumVal)))
        If NumVal > 0 And NumVal < 7 Then
            NumBytes = NumBytes Or 2 ^ (NumVal + 2)
        End If
        If PackedOrNot = 0 Then
            For X = 1 To NumBytes       'the bytes aren't Grouped
                OutStream(NewPos) = ReadBitsFromArray(ByteArray, InpPos, 8)
                NewPos = NewPos + 1
            Next
        Else
            LowInGroup = ReadBitsFromArray(ByteArray, InpPos, 8)
            For X = 1 To NumBytes       'the bytes are Grouped
                OutStream(NewPos) = ReadBitsFromArray(ByteArray, InpPos, 6) + LowInGroup
                NewPos = NewPos + 1
            Next
        End If
    Loop
    ReDim ByteArray(TotFileLen)
    Call CopyMem(ByteArray(0), OutStream(0), TotFileLen + 1)
End Sub

Private Function ReadBitsFromArray(FromArray() As Byte, FromPos As Long, 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 - ReadBitPos)) > 0))
        ReadBitPos = ReadBitPos + 1
        If ReadBitPos = 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
            ReadBitPos = 0
        End If
    Next
    ReadBitsFromArray = Temp
End Function

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品国产精品国产专区不片| 久久精品99国产国产精| 亚洲午夜一区二区三区| 国产专区欧美精品| 欧美视频在线一区二区三区| 精品毛片乱码1区2区3区| 亚洲嫩草精品久久| 国产乱码字幕精品高清av | 久久综合给合久久狠狠狠97色69| 中文字幕亚洲一区二区va在线| 日韩高清不卡一区二区| 成人精品视频一区二区三区尤物| 欧美肥妇毛茸茸| 亚洲美女视频一区| 成人免费视频网站在线观看| 日韩欧美国产电影| 日韩国产成人精品| 欧美撒尿777hd撒尿| 国产精品美女久久久久aⅴ| 日本怡春院一区二区| 欧洲视频一区二区| 亚洲人亚洲人成电影网站色| 加勒比av一区二区| 日韩免费观看高清完整版在线观看| 亚洲天堂免费在线观看视频| 国产精品小仙女| 亚洲精品一区二区三区影院| 亚洲aⅴ怡春院| 欧美性猛交一区二区三区精品| 国产精品美女久久久久aⅴ| 国产精品99久久久久久宅男| 日韩欧美国产午夜精品| 日本最新不卡在线| 91精品国产丝袜白色高跟鞋| 亚洲国产一区二区三区| 91香蕉国产在线观看软件| 国产色91在线| 国产激情一区二区三区桃花岛亚洲| 欧美一级理论性理论a| 日韩av在线免费观看不卡| 7777精品伊人久久久大香线蕉| 亚洲在线视频免费观看| 在线视频你懂得一区二区三区| 综合久久久久综合| 日本韩国欧美一区二区三区| 自拍偷拍亚洲综合| 91美女蜜桃在线| 一区二区国产盗摄色噜噜| 在线观看日韩高清av| 亚洲国产人成综合网站| 7777精品伊人久久久大香线蕉超级流畅| 亚洲电影第三页| 欧美电影免费观看高清完整版 | 亚洲靠逼com| www.99精品| 亚洲小说春色综合另类电影| 欧美日韩视频在线第一区 | 日本一不卡视频| 欧美videos大乳护士334| 国产一区二区三区免费看| 亚洲国产精品激情在线观看| 99热这里都是精品| 亚洲成人午夜影院| 日韩欧美的一区二区| 国产成人自拍网| 日韩毛片精品高清免费| 69成人精品免费视频| 国产一区二区三区高清播放| 中文字幕在线不卡| 在线播放亚洲一区| 成人三级伦理片| 亚洲成人动漫在线观看| 欧美精品一区在线观看| 一本色道久久加勒比精品| 午夜激情久久久| 国产欧美日韩在线| 欧美乱妇15p| 国产精品羞羞答答xxdd| 亚洲成人自拍一区| 国产日韩欧美一区二区三区乱码| 色天天综合久久久久综合片| 日本欧美一区二区在线观看| 国产三区在线成人av| 欧美高清一级片在线| 福利电影一区二区| 日本vs亚洲vs韩国一区三区二区 | 欧美天堂一区二区三区| 国产在线视频一区二区| 亚洲主播在线播放| 国产精品亲子乱子伦xxxx裸| 91精品国产色综合久久不卡蜜臀| 成人av资源在线| 精品一区二区三区日韩| 亚洲黄色av一区| 中文字幕av资源一区| 91麻豆精品国产自产在线| av午夜精品一区二区三区| 久久国产综合精品| 午夜日韩在线观看| ...xxx性欧美| 国产午夜精品美女毛片视频| 7777精品伊人久久久大香线蕉 | 成人免费毛片app| 毛片av中文字幕一区二区| 亚洲尤物视频在线| 亚洲欧美激情插| 中文字幕一区三区| 久久久久久久免费视频了| 日韩一区二区三区免费观看| 欧美色男人天堂| 欧洲av一区二区嗯嗯嗯啊| www.性欧美| 国产福利一区在线观看| 国产伦精品一区二区三区在线观看| 婷婷国产在线综合| 丝袜亚洲另类丝袜在线| 亚洲成av人影院在线观看网| 一区二区国产盗摄色噜噜| 亚洲乱码中文字幕| 一区二区三区免费| 一区二区三区中文在线| 一区二区高清免费观看影视大全 | 午夜天堂影视香蕉久久| 亚洲最大的成人av| 一级女性全黄久久生活片免费| 亚洲欧美日韩国产成人精品影院| 国产精品久久久久一区二区三区共 | 国产精品国产三级国产aⅴ入口| 国产亚洲成av人在线观看导航| 久久亚洲一级片| 国产亚洲人成网站| 欧美激情一区二区| 中文字幕在线观看一区| 一区二区三区精品| 亚洲成人动漫在线观看| 日本不卡的三区四区五区| 婷婷亚洲久悠悠色悠在线播放| 蜜芽一区二区三区| 国产在线播精品第三| 成人一二三区视频| 色综合咪咪久久| 欧美日本一区二区三区四区| 欧美一级黄色片| 国产日韩欧美精品电影三级在线 | 国产农村妇女精品| 自拍偷拍欧美激情| 亚洲成a人片在线观看中文| 免费不卡在线视频| av电影一区二区| 欧美日韩精品一区二区| 欧美成人综合网站| 椎名由奈av一区二区三区| 午夜视频久久久久久| 国产精品一区专区| 色爱区综合激月婷婷| 日韩情涩欧美日韩视频| 国产精品色噜噜| 性欧美疯狂xxxxbbbb| 国产馆精品极品| 精品免费国产二区三区| 自拍av一区二区三区| 蜜臀a∨国产成人精品| 不卡一区二区在线| 欧美一二三在线| 亚洲视频网在线直播| 另类小说视频一区二区| 91在线你懂得| 精品欧美一区二区久久| 亚洲欧美另类久久久精品2019| 麻豆精品新av中文字幕| 91免费视频观看| 精品国产乱码久久久久久图片| 自拍偷拍亚洲综合| 九色porny丨国产精品| 在线国产电影不卡| 国产精品美女久久久久av爽李琼| 午夜婷婷国产麻豆精品| 91视频com| 国产欧美一区二区精品性| 日韩电影在线一区| 色呦呦国产精品| 国产女人18毛片水真多成人如厕 | 欧美成人aa大片| 亚洲综合在线电影| a级精品国产片在线观看| 日韩美女在线视频| 亚洲成人免费在线| 色综合天天综合网国产成人综合天| 精品国产91亚洲一区二区三区婷婷| 亚洲国产中文字幕| 色婷婷综合久色| 国产精品久久久久婷婷| 国产综合一区二区| 欧美成人一区二区三区片免费 | 亚洲欧美二区三区| 成人高清在线视频| 国产喷白浆一区二区三区| 看电影不卡的网站| 日韩欧美美女一区二区三区| 天堂成人免费av电影一区|