Use the Linked List included in this document to implement the following methods. These methods are hard! Once you master these exercises you'll be an expert at Linked Lists.
Find center
Finding the center element of a linked list is a classic interview problem. First, try to produce code that can get the right answer (regardless of efficiency). Then, try to get it done in O(n) time. You can assume that the list will be odd in length.
Reverse
If you finish the find center method before we run out of time, try another classic problem, reversing a linked list.
This should be completed in O(n) time and needs to be done in place (shouldn't use any insert commands).
classNodeattr_accessor:data,:nextdefinitializedata @data = data @next =nilenddefto_s output = @data.to_s output +=' > '+ @next.to_sunless @next.nil? outputendendclassLinkedListattr_accessor:head,:taildefinitialize @head =nil @tail =nilenddefinsert_frontdata temp = @head @head =Node.new(data) @head.next= temp @tail = @head if @tail.nil?enddefinsert_enddata temp = @tail @tail =Node.new(data) temp.next= @tail unless temp.nil? @head = @tail if @head.nil?enddefto_s @head.to_senddefget_center#code solution for center hereenddefreverse#bonus - code solution for reverse hereendendlist = LinkedList.newlist.insert_front1list.insert_front3list.insert_front5list.insert_front7list.insert_front9#outputs: 9 > 7 > 5 > 3 > 1puts list#needs to output: 5puts list.get_center.data#needs to output: 1 > 3 > 5 > 7 > 9list.reverseputs list