How to extends ruby classes

Add the quickshort algorithm to the array class.

     class Array
        def qs
            return self if size <=1
            pivot = shift
            less, more = partition{ |y| y < pivot }
            [*less.qs, pivot, *more.qs]
        end
    end

Add the factorial operation to the integer class

    class Integer
        def factorial
            return 1 if self <= 1
            self * (self-1).factorial
        end
    end
Advertisements

No comments yet

Leave a Reply

Fill in your details below or click an icon to log in:

WordPress.com Logo

You are commenting using your WordPress.com account. Log Out / Change )

Twitter picture

You are commenting using your Twitter account. Log Out / Change )

Facebook photo

You are commenting using your Facebook account. Log Out / Change )

Google+ photo

You are commenting using your Google+ account. Log Out / Change )

Connecting to %s

%d bloggers like this: