1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27
|
'Tri ListBox2(Col 1)
Private Sub CmdTRI1_Click()
Dim Tbl()
Tbl = Me.ListBox2.List
Tri Tbl, LBound(Tbl), UBound(Tbl), 1
Me.ListBox2.List = Tbl
End Sub
Sub Tri(a(), gauc, droi, colTri) ' Quick sort
Dim colD, colF, ref, g, d, c, temp
colD = LBound(a, 2): colF = UBound(a, 2)
ref = a((gauc + droi) \ 2, colTri)
g = gauc: d = droi
Do
Do While a(g, colTri) < ref: g = g + 1: Loop
Do While ref < a(d, colTri): d = d - 1: Loop
If g <= d Then
For c = colD To colF
temp = a(g, c): a(g, c) = a(d, c): a(d, c) = temp
Next
g = g + 1: d = d - 1
End If
Loop While g <= d
If g < droi Then Tri a, g, droi, colTri
If gauc < d Then Tri a, gauc, d, colTri
End Sub |
Partager