Guest User

Untitled

a guest
Jun 21st, 2018
72
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 0.67 KB | None | 0 0
  1. class LinkedListNode
  2. attr_accessor :value, :next_node
  3.  
  4. def initialize(value, next_node=nil)
  5. @value = value
  6. @next_node = next_node
  7. end
  8. end
  9.  
  10. def print_values(list_node)
  11. if list_node
  12. print "#{list_node.value} --> "
  13. print_values(list_node.next_node)
  14. else
  15. print "nil\n"
  16. return
  17. end
  18. end
  19.  
  20. def reverse_list(list, previous=nil)
  21. if list
  22. next_node = list.next_node
  23. list.next_node = previous
  24. reverse_list(next_node, list)
  25. end
  26. end
  27.  
  28. node1 = LinkedListNode.new(37)
  29. node2 = LinkedListNode.new(99, node1)
  30. node3 = LinkedListNode.new(12, node2)
  31.  
  32. print_values(node3)
  33. reverse_list(node3)
  34. print_values(node1)
Add Comment
Please, Sign In to add comment