Sha256: b339d186d2265a4a2e7316346eba5fa6a661d99c468e7500a44b4cbfca123bcf
Contents?: true
Size: 1.42 KB
Versions: 1
Compression:
Stored size: 1.42 KB
Contents
require_relative 'data_struct_list/version.rb' module DataStructList class Head attr_accessor :quant, :next, :prev def initialize @quant = 0 end end class Node attr_accessor :hash, :next attr_reader :id def initialize(hash) @@id_quantify ||= 0 @id = @@id_quantify @@id_quantify+=1 @hash = hash @next = nil end end class SimpleLinkedList attr_reader :first, :last, :head def initialize @head = Head.new @first = nil @last = nil end def insert(hash) if @head.quant == 0 then @head.next = Node.new(hash) @first = @head.next @last = @head.next @head.quant += 1 else @last.next = Node.new(hash) @last = @last.next @head.quant += 1 end return @last.id end def find(id) elm = @first until elm == nil if elm.id == id then break end elm = elm.next end return elm end def remove(id) elm = @first aux = @first until elm == nil if elm.id == id then break end aux = elm elm = elm.next end if elm!=nil then aux.next = elm.next @head.quant -= 1 if elm == @head.next @first = elm.next @head.next = @first end if @last == elm then @last = aux end elm = nil end end end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
data_struct_list-0.1.1 | lib/data_struct_list.rb |