Class: Zadt::MinMaxStack

Inherits:
Object
  • Object
show all
Defined in:
lib/zadt/AbstractDataTypes/StackQueue/MinMaxStack.rb

Class Method Summary collapse

Instance Method Summary collapse

Constructor Details

#initializeMinMaxStack

Returns a new instance of MinMaxStack.



6
7
8
# File 'lib/zadt/AbstractDataTypes/StackQueue/MinMaxStack.rb', line 6

def initialize
  @values = []
end

Class Method Details

.helpObject



10
11
12
# File 'lib/zadt/AbstractDataTypes/StackQueue/MinMaxStack.rb', line 10

def self.help
  Zadt::ADT::show_minmaxstack_help_message
end

Instance Method Details

#empty?Boolean

Returns:

  • (Boolean)


54
55
56
# File 'lib/zadt/AbstractDataTypes/StackQueue/MinMaxStack.rb', line 54

def empty?
  @values.empty?
end

#helpObject



14
15
16
# File 'lib/zadt/AbstractDataTypes/StackQueue/MinMaxStack.rb', line 14

def help
  MinMaxStack.help
end

#lengthObject



45
46
47
# File 'lib/zadt/AbstractDataTypes/StackQueue/MinMaxStack.rb', line 45

def length
  @values.length
end

#maxObject



41
42
43
# File 'lib/zadt/AbstractDataTypes/StackQueue/MinMaxStack.rb', line 41

def max
  @values.empty? ? "Empty" : @values.last[2]
end

#minObject



37
38
39
# File 'lib/zadt/AbstractDataTypes/StackQueue/MinMaxStack.rb', line 37

def min
  @values.empty? ? "Empty" : @values.last[1]
end

#peekObject



33
34
35
# File 'lib/zadt/AbstractDataTypes/StackQueue/MinMaxStack.rb', line 33

def peek
  @values.last[0]
end

#popObject



29
30
31
# File 'lib/zadt/AbstractDataTypes/StackQueue/MinMaxStack.rb', line 29

def pop
  @values.pop[0]
end

#push(val) ⇒ Object



18
19
20
21
22
23
24
25
26
27
# File 'lib/zadt/AbstractDataTypes/StackQueue/MinMaxStack.rb', line 18

def push(val)
  if @values.empty?
    @values.push([val, val, val])
  else
    cur_min = @values.last[1]
    cur_max = @values.last[2]
    @values.push([val, [val, cur_min].min, [val, cur_max].max])
    @values
  end
end

#showObject



49
50
51
52
# File 'lib/zadt/AbstractDataTypes/StackQueue/MinMaxStack.rb', line 49

def show
  showthis = []
  @values.map{|value| value[0]}
end