The Odin Project - Ruby Programming - Project: Advanced Building Blocks
Build a method #bubble_sort that takes an array and returns a sorted array. It must use the bubble sort methodology (using #sort would be pretty pointless, wouldn’t it?).
> bubble_sort([4,3,78,2,0,2])
=> [0,2,2,3,4,78]
Now create a similar method called #bubble_sort_by which sorts an array by accepting a block. Remember to use yield inside your method definition to accomplish this. The block will have two arguments that represent the two elements of the array that are currently being compared. The block’s return will be similar to the spaceship operator you learned about before: If the result of the block execution is negative, the element on the left is “smaller” than the element on the right. 0 means both elements are equal. A positive result means the left element is greater. Use the block’s return value to sort your array. Test your method with the example below.
> bubble_sort_by(["hi","hello","hey"]) do |left,right|
> left.length - right.length
> end
=> ["hi", "hey", "hello"]
-
Create a script file to house your methods and run it in IRB to test them later.
-
Add your new methods onto the existing Enumerable module. Ruby makes this easy for you because any class or module can be added to without trouble … just do something like: module Enumerable def my_each # your code here end end
-
Create #my_each, a method that is identical to #each but (obviously) does not use #each. You’ll need to remember the yield statement. Make sure it returns the same thing as #each as well.
-
Create #my_each_with_index in the same way.
-
Create #my_select in the same way, though you may use #my_each in your definition (but not #each).
-
Create #my_all? (continue as above)
-
Create #my_any?
-
Create #my_none?
-
Create #my_count
-
Create #my_map
-
Create #my_inject
-
Test your #my_inject by creating a method called #multiply_els which multiplies all the elements of the array together by using #my_inject, e.g. multiply_els([2,4,5]) #=> 40
-
Modify your #my_map method to take a proc instead.
-
Modify your #my_map method to take either a proc or a block. It won’t be necessary to apply both a proc and a block in the same #my_map call since you could get the same effect by chaining together one #my_map call with the block and one with the proc. This approach is also clearer, since the user doesn’t have to remember whether the proc or block will be run first. So if both a proc and a block are given, only execute the proc.