vba冒泡排序与选择排序

1. vba冒泡排序

Option Explicit

Sub SelectionSort()
    Dim arr, i, j, temp
    arr = Array(1, 9, 10, 5, 4)
    PrintArr (arr)
    For i = LBound(arr) To UBound(arr) - 1
        For j = LBound(arr) To UBound(arr) - 1 - i
            If arr(j) > arr(j + 1) Then
                temp = arr(j) '小的放在前面,大的放到后面
                arr(j) = arr(j + 1)
                arr(j + 1) = temp
            End If
        Next j
        
    Next
    PrintArr (arr)
End Sub


Sub PrintArr(arr)
    Dim i
    Debug.Print ("=========================")
    For i = LBound(arr) To UBound(arr)
        Debug.Print arr(i)
    Next
End Sub

2. vba 选择排序

Option Explicit

Sub SelectionSort()
    Dim arr, i, j, k, temp
    arr = Array(1, 9, 10, 5, 4)
    PrintArr (arr)
    For i = LBound(arr) To UBound(arr)
        k = i
        For j = k + 1 To UBound(arr)
            If arr(j) < arr(k) Then
                k = j ' 记下较小值的位置
            End If
        Next j
        
        If i <> k Then
            temp = arr(i)
            arr(i) = arr(k)
            arr(k) = temp
        End If
    Next
    PrintArr (arr)
End Sub


Sub PrintArr(arr)
    Dim i
    Debug.Print ("=========================")
    For i = LBound(arr) To UBound(arr)
        Debug.Print arr(i)
    Next
End Sub

 

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值