Sorting algorithms/Strand sort: Difference between revisions

→‎{{header|Ruby}}: used partition
(Nimrod -> Nim)
(→‎{{header|Ruby}}: used partition)
Line 1,426:
<lang ruby>class Array
def strandsort
a = self.dup
result = []
until a.empty?
sublistv = [a.shift]first
sublist, a = a.partition{|val| v=val if v<=val} # In case of v>val, it becomes nil.
a.each_with_index.each_with_object([]) { |(val, idx), remove|
next if val <= sublist.last
sublist << val
remove << idx
}.reverse_each {|idx| a.delete_at(idx)}
result.each_index do |idx|
break if sublist.empty?
result.insert(idx, sublist.shift) if sublist[0].first < result[idx]
end
result += sublist
Line 1,452 ⟶ 1,448:
p [1, 6, 3, 2, 1, 7, 5, 3].strandsort</lang>
 
{{out}}
result
<pre>[1, 1, 2, 3, 3, 5, 6, 7]</pre>
 
Anonymous user