Scala 实现归并排序、快速排序

@羲凡——只为了更好的活着

Scala 实现归并排序、快速排序

原文链接 https://blog.csdn.net/qq1010885678/article/details/46755749 。这位仁兄对scala的list、模式匹配和递归的理解非常深刻,第一看惊为天作,这个算法还能这么写,牛逼呀。

1.归并排序

def mergedSort[T](less: (T, T) => Boolean)(list: List[T]): List[T] = {
  def merged(xList: List[T], yList: List[T]): List[T] = {
    (xList, yList) match {
      case (Nil, _) => yList
      case (_, Nil) => xList
      case (x :: xTail, y :: yTail) => {
        if (less(x, y)) 
          x :: merged(xTail, yList)
        else
          y :: merged(xList, yTail)
      }
    }
  }
  val n = list.length / 2
  if (n == 0) list
  else {
    val (x, y) = list splitAt n
    merged(mergedSort(less)(x), mergedSort(less)(y))
  }
}

2.快速排序

def quickSort(list:List[Int]): List[Int] ={
  list match {
    case Nil => Nil
    case List() => List()
    case head :: tail =>
      val (left,right) = tail.partition(_ < head)
      quickSort(left) ::: head :: quickSort(right)
  }
}

====================================================================

@羲凡——只为了更好的活着

若对博客中有任何问题,欢迎留言交流

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值