Scala实现快速排序

 //快速排序
  def quickSort(array: Array[Int], low: Int, high: Int): Array[Int] = {
    var key = array(low)
    var i = low
    var j = high
    while (i < j) {
      //右到左遍历
      while (i < j && array(j) >= key) {
        j -= 1
      }
      if(i<j) {
        array(i) = array(j)
        i += 1
      }
      //左到右遍历
      while (i < j && array(i) <= key) {
        i += 1
      } 
      if(i<j) {
        array(j) = array(i)
        j -= 1
      }
      //每一趟结束时i==j
      array(i) = key
    }
    //每一趟结束遍历数组
    //array.foreach(x => print(x + " "))
    println()
    //递归调用完成排序
    if (low < i - 1) quickSort(array, low, i - 1)
    if (j + 1 < high) quickSort(array, j + 1, high)

    return array
  }
 val array1 = Array(2,3,9,6,4,7,1,5,8)
 quickSort(array1,0,array1.length-1).foreach(x=>print(x+" "))
结果如下:
1 2 3 4 5 6 7 8 9 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值