'冒泡排序
Sub BubbleSort0(MyArray(), Optional ByVal SortByDesc As Boolean)
Dim Index
Dim temp
Dim NextElement
'先将已处理的元素个数置为0
NextElement = 0
'遍历每一个元素
Do While (NextElement < UBound(MyArray))
'读取当前最大下标
Index = UBound(MyArray)
'与前面的每一个元素比较
Do While (Index > NextElement)
'根据是升序或降序进行分别处理
If SortByDesc = False Then
'升序:如果当前值小于上一个值,则互换
If MyArray(Index) < MyArray(Index - 1) Then
temp = MyArray(Index)
MyArray(Index) = MyArray(Index - 1)
MyArray(Index - 1) = temp
End If
ElseIf SortByDesc = True Then
'降序:如果当前值大于上一个值,则互换
If MyArray(Index) > MyArray(Index - 1) Then
temp = MyArray(Index)
MyArray(Index) = MyArray(Index - 1)
MyArray(Index - 1) = temp
End If
End If
'将当前下标移到上一个值
Index = Index - 1
Loop
'将已处理的元素个数加1
NextElement = NextElement + 1
Loop
End Sub
VB排序算法-冒泡排序
这是一个使用VB编写的冒泡排序算法实现,可以根据升序或降序需求进行排序。算法通过遍历数组,比较相邻元素并交换位置来逐步排序整个数组。
226





