/ruby-algorithms

Implementing various algorithms using Ruby

Primary LanguageRuby

Ruby Alogrithms

My own implementation of various algorithms in Ruby. I will try to include performance number as well.

Binary Search

In lib/binary_search.rb

Comparison with Ruby's any? method.

$ ruby ./spec/search_performance.rb
                   user       system     total    real
array.any?         0.010000   0.000000   0.010000 (  0.007985)
BinarySearch.find  0.030000   0.000000   0.030000 (  0.025298)

Linked List

In lib/linked_list.rb

$ irb
1.9.3-p194 :001 > load 'lib/linked_list.rb'
 => true
1.9.3-p194 :002 > node1 = LinkedList.new(1)
 => #<LinkedList:0x007fead39de570 @content="1">
1.9.3-p194 :003 > node2 = LinkedList.new(2)
 => #<LinkedList:0x007fead39e1b08 @content="2">
1.9.3-p194 :004 > node3 = LinkedList.new(3)
 => #<LinkedList:0x007fead39e4308 @content="3">
1.9.3-p194 :005 > node1.next_node = node2
 => #<LinkedList:0x007fead39e1b08 @content="2">
1.9.3-p194 :006 > node2.next_node = node3
 => #<LinkedList:0x007fead39e4308 @content="3">
1.9.3-p194 :007 > node1.print_nodes
 => "1 -> 2 -> 3"
1.9.3-p194 :008 > node2.print_nodes
 => "2 -> 3"
1.9.3-p194 :009 > node3.print_nodes
 => "3"
1.9.3-p194 :010 > node1.reverse
 => nil
1.9.3-p194 :011 > node3.print_nodes
 => "3 -> 2 -> 1"

Bubble Sort

In lib/custom_sort.rb, bubble_sort method.

$ irb
1.9.3-p194 :001 > load 'lib/custom_sort.rb'
 => true
1.9.3-p194 :002 > array = CustomSort.new([1, 4, 3, 2, 5])
 => #<CustomSort:0x007fabf389a0e8 @base=[1, 4, 3, 2, 5]>
1.9.3-p194 :003 > array.bubble_sort
 => [5, 4, 3, 2, 1]

Selection Sort

In lib/custom_sort.rb, selection_sort method.

$ irb
1.9.3-p194 :001 > load 'lib/custom_sort.rb'
 => true
1.9.3-p194 :002 > array = CustomSort.new([1, 4, 3, 2, 5])
 => #<CustomSort:0x007fb0dab6d5b8 @base=[1, 4, 3, 2, 5]>
1.9.3-p194 :003 > array.selection_sort
 => [1, 2, 3, 4, 5]

Merge Sort

In lib/custom_sort.rb, merge_sort method.

$ irb
1.9.3-p194 :001 > load 'lib/custom_sort.rb'
 => true
1.9.3-p194 :002 > array = CustomSort.new([1, 4, 3, 2, 5])
 => #<CustomSort:0x007fb0dab6d5b8 @base=[1, 4, 3, 2, 5]>
1.9.3-p194 :003 > array.merge_sort
 => [1, 2, 3, 4, 5]

Quick Sort

In lib/custom_sort.rb, quick_sort method.

$ irb
1.9.3-p194 :001 > load 'lib/custom_sort.rb'
 => true
1.9.3-p194 :002 > array = CustomSort.new([1, 4, 3, 2, 5])
 => #<CustomSort:0x007fb0dab6d5b8 @base=[1, 4, 3, 2, 5]>
1.9.3-p194 :003 > array.quick_sort
 => [1, 2, 3, 4, 5]

Insertion Sort

In lib/custom_sort.rb, insertion_sort method.

$ irb
1.9.3-p194 :001 > load 'lib/custom_sort.rb'
 => true
1.9.3-p194 :002 > array = CustomSort.new([1, 4, 3, 2, 5])
 => #<CustomSort:0x007fb0dab6d5b8 @base=[1, 4, 3, 2, 5]>
1.9.3-p194 :003 > array.insertion_sort
 => [1, 2, 3, 4, 5]

Sorting Performance Comparison

Using an array with size of 10000 with random integers.

array = (1..1000).map { rand(2**32-1) + 1 }
to_sort = CustomSort.new(array)
$ ruby ./spec/sorting_performance.rb
                   user     system      total        real
Bubble Sort     0.270000   0.000000   0.270000 (  0.264657)
Selection Sort  0.090000   0.000000   0.090000 (  0.093256)
Merge Sort      0.010000   0.000000   0.010000 (  0.004939)
Quick Sort      0.140000   0.010000   0.150000 (  0.156909)
Insertion Sort  0.010000   0.000000   0.010000 (  0.000416)