Sorting algorithms/Quicksort: Difference between revisions

Content added Content deleted
Line 3,571:
def quick_sort
return self if length <= 1
pivot = self[length / 2]sample
find_all { |i| i < pivot }.quick_sort +
find_all { |i| i == pivot } +
Line 3,583:
pivot = self[0]
less, greatereq = self[1..-1].partition { |x| x < pivot }
less.quick_sort + [pivot] + greatereq.quick_sort
[pivot] +
greatereq.quick_sort
end
end</lang>
or
<lang ruby>class Array
def greatereq.quick_sort
return self if length <= 1
pivot = sample
group = group_by{ |x| x <=> pivot }
group.default = []
group[-1].quick_sort + group[0] + group[1].quick_sort
end
end</lang>
 
=={{header|Run BASIC}}==
<lang runbasic>' -------------------------------