mirror of
https://github.com/jashkenas/coffeescript.git
synced 2022-11-09 12:23:24 -05:00
19 lines
No EOL
537 B
CoffeeScript
19 lines
No EOL
537 B
CoffeeScript
# Sorts an array in ascending natural order using merge sort.
|
|
merge_sort = (list) ->
|
|
|
|
return list if list.length is 1
|
|
|
|
result = []
|
|
pivot = Math.floor list.length / 2
|
|
left = merge_sort list.slice 0, pivot
|
|
right = merge_sort list.slice pivot
|
|
|
|
while left.length and right.length
|
|
result.push(if left[0] < right[0] then left.shift() else right.shift())
|
|
|
|
result.concat(left).concat(right)
|
|
|
|
|
|
# Test the function.
|
|
puts merge_sort([3, 2, 1]).join(' ') is '1 2 3'
|
|
puts merge_sort([9, 2, 7, 0, 1]).join(' ') is '0 1 2 7 9' |