This is a set of procedures you can use to sort lists and tables, using your own test criterion for greater/lesser comparison. It is based on the merge sort algorithm, which runs at n*log(n) speed. The procedure blocks should be draggable directly into your Blocks Editor workspace.
data:image/s3,"s3://crabby-images/fab1a/fab1ad71482153d9c09f45515f8da3d1e628679e" alt="merge_sort_sample_call"
data:image/s3,"s3://crabby-images/6714b/6714bcca8070f89ae15781322e44136d5ae93394" alt="output"
data:image/s3,"s3://crabby-images/13951/13951f7842c3b85d1485ffd5e6bd82e938f3bf0c" alt="precedes"
data:image/s3,"s3://crabby-images/4e1e4/4e1e429f6f11b16bd8c982f18fae2ad7af53fc48" alt="randoms"
The logic:
function merge_sort(list m)
// Base case. A list of zero or one elements is sorted, by definition.
if length of m ≤ 1 then
return m// Recursive case. First, divide the list into equal-sized sublists // consisting of the first half and second half of the list. var left := empty list var right := empty list for each x with index i in m do if i ≤ (length of m)/2 then add x to left else add x to right // Recursively sort both sublists. left := merge_sort(left) right := merge_sort(right) // Then merge the now-sorted sublists. return merge(left, right)
Merge function logic:
function merge(left, right)
var result := empty listwhile left is not empty and right is not empty do if first(left) ≤ first(right) then append first(left) to result left := rest(left) else append first(right) to result right := rest(right) // Either left or right may have elements left; consume them. // (Only one of the following loops will actually be entered.) while left is not empty do append first(left) to result left := rest(left) while right is not empty do append first(right) to result right := rest(right) return result