Sub QuickSort(SortArray, col, L, R, bAscending)
'
'Originally Posted by Jim Rech 10/20/98 Excel.Programming
'Modified to sort on first column of a two dimensional array
'Modified to handle a second dimension greater than 1 (or zero)
'Modified to sort on a specified column in a 2D array
'Modified to do Ascending or Descending
    Dim i, j, X, Y, mm
    i = L
    j = R
    X = SortArray((L + R) / 2, col)
  If bAscending Then
    While (i <= j)
        While (SortArray(i, col) < X And i < R)
            i = i + 1
        Wend
        While (X < SortArray(j, col) And j > L)
            j = j - 1
        Wend
        If (i <= j) Then
          For mm = LBound(SortArray, 2) To UBound(SortArray, 2)
            Y = SortArray(i, mm)
            SortArray(i, mm) = SortArray(j, mm)
            SortArray(j, mm) = Y
          Next mm
            i = i + 1
            j = j - 1
        End If
    Wend
  Else
    While (i <= j)
        While (SortArray(i, col) > X And i < R)
            i = i + 1
        Wend
        While (X > SortArray(j, col) And j > L)
            j = j - 1
        Wend
        If (i <= j) Then
          For mm = LBound(SortArray, 2) To UBound(SortArray, 2)
            Y = SortArray(i, mm)
            SortArray(i, mm) = SortArray(j, mm)
            SortArray(j, mm) = Y
          Next mm
            i = i + 1
            j = j - 1
        End If
    Wend
  End If
    If (L < j) Then Call QuickSort(SortArray, col, L, j, bAscending)
    If (i < R) Then Call QuickSort(SortArray, col, i, R, bAscending)
End Sub