Add Gnome Sort (aka "Stupid Sort")

This commit is contained in:
Andrew H Yi 2017-10-01 18:54:20 -04:00
parent 5cd15d08d8
commit 3fa5d83171
2 changed files with 35 additions and 0 deletions

21
GnomeSort.rb Normal file
View file

@ -0,0 +1,21 @@
class GnomeSort
def self.sort!(arr)
i, j = 1, 2
while i < arr.length
if arr[i-1] <= arr[i]
i, j = j, j+1
else
arr[i-1], arr[i] = arr[i], arr[i-1]
i -= 1 if i > 1
end
end
arr
end
end
puts "Enter a list of numbers separated by spaces"
str = gets.chomp
numbers = str.split(" ").map(&:to_i)
GnomeSort.sort!(numbers)
puts numbers

View file

@ -59,3 +59,17 @@ __Properties__
[insertion-toptal]: https://www.toptal.com/developers/sorting-algorithms/insertion-sort [insertion-toptal]: https://www.toptal.com/developers/sorting-algorithms/insertion-sort
[insertion-wiki]: https://en.wikipedia.org/wiki/Insertion_sort [insertion-wiki]: https://en.wikipedia.org/wiki/Insertion_sort
[insertion-image]: https://upload.wikimedia.org/wikipedia/commons/7/7e/Insertionsort-edited.png "Insertion Sort" [insertion-image]: https://upload.wikimedia.org/wikipedia/commons/7/7e/Insertionsort-edited.png "Insertion Sort"
### Gnome Sort (aka "Stupid Sort")
![alt text][gnome-image]
From [Wikipedia][gnome-wiki]: The algorithm always finds the first place where two adjacent elements are in the wrong order, and swaps them. It takes advantage of the fact that performing a swap can introduce a new out-of-order adjacent pair only next to the two swapped elements. It does not assume that elements forward of the current position are sorted, so it only needs to check the position directly previous to the swapped elements.
__Properties__
* Worst case performance O(n^2)
* Best case performance O(n)
* Average case performance O(n^2)
[gnome-wiki]: https://en.wikipedia.org/wiki/Gnome_sort
[gnome-image]: https://upload.wikimedia.org/wikipedia/commons/3/37/Sorting_gnomesort_anim.gif "Gnome Sort"