summaryrefslogtreecommitdiffstats
path: root/Scala
diff options
context:
space:
mode:
authorJérémy Zurcher <jeremy@asynk.ch>2013-05-09 21:40:09 +0200
committerJérémy Zurcher <jeremy@asynk.ch>2016-11-10 18:03:24 +0100
commitb9149e400c09d1f7d4bcf607d8e7b6b2c04b33d4 (patch)
treea6d0d88c12fb430fb90e5e87483b242667b25866 /Scala
parenta92840a4e19676b0b6afc916d0a65243f42dc5e5 (diff)
downloadcoursera-b9149e400c09d1f7d4bcf607d8e7b6b2c04b33d4.zip
coursera-b9149e400c09d1f7d4bcf607d8e7b6b2c04b33d4.tar.gz
Scala : generalize merge sort
Diffstat (limited to 'Scala')
-rw-r--r--Scala/sandbox/10-merge-sort.scala23
1 files changed, 23 insertions, 0 deletions
diff --git a/Scala/sandbox/10-merge-sort.scala b/Scala/sandbox/10-merge-sort.scala
index 5cf0b44..04aa38d 100644
--- a/Scala/sandbox/10-merge-sort.scala
+++ b/Scala/sandbox/10-merge-sort.scala
@@ -1,5 +1,6 @@
object MergeSort
{
+ import math.Ordering
def msort[T](xs: List[T])(lt: (T, T) => Boolean): List[T] = {
val n = xs.length/2
@@ -18,10 +19,32 @@ object MergeSort
}
}
+ /* def msortO[T](xs: List[T])(ord: Ordering[T]): List[T] = { */
+ def msortO[T](xs: List[T])(implicit ord: Ordering[T]): List[T] = {
+ val n = xs.length/2
+ if (n==0) xs
+ else {
+ def merge(xs: List[T], ys: List[T]): List[T] = (xs, ys) match {
+ case (Nil, ys) => ys
+ case (xs, Nil) => xs
+ case (x :: xs1, y :: ys1) => {
+ if (ord.lt(x, y)) x :: merge(xs1, ys)
+ else y :: merge(xs, ys1)
+ }
+ }
+ val (fst, snd) = xs splitAt n
+ /* merge(msortO(fst)(ord), msortO(snd)(ord)) */
+ merge(msortO(fst), msortO(snd))
+ }
+ }
+
def run = {
println("MergeSort")
val nums = List(2, 8, -2, 9, 2, 6, 0, 7, 1)
val sorted = msort(nums)((x: Int, y: Int) => x < y)
println(sorted)
+ /* val sorted2 = msortO(nums)(Ordering.Int) */
+ val sorted2 = msortO(nums)
+ println(sorted2)
}
}