Class: Zadt::MinMaxStack

Inherits:
Object
  • Object
show all
Defined in:
lib/zadt/AbstractDataTypes/MinMaxStackQueue/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/MinMaxStackQueue/MinMaxStack.rb', line 6

def initialize
  @values = []
end

Class Method Details

.helpObject



10
11
12
13
14
15
16
17
18
19
20
# File 'lib/zadt/AbstractDataTypes/MinMaxStackQueue/MinMaxStack.rb', line 10

def self.help
  puts "Here are the functions for MinMaxStack:"
  puts "#push(value)"
  puts "#pop"
  puts "#peek"
  puts "#min"
  puts "#max"
  puts "#length"
  puts "#show"
  puts "#empty?"
end

.methodsObject



22
23
24
# File 'lib/zadt/AbstractDataTypes/MinMaxStackQueue/MinMaxStack.rb', line 22

def self.methods
  self.help
end

Instance Method Details

#empty?Boolean

Returns:

  • (Boolean)


70
71
72
# File 'lib/zadt/AbstractDataTypes/MinMaxStackQueue/MinMaxStack.rb', line 70

def empty?
  @values.empty?
end

#helpObject



26
27
28
# File 'lib/zadt/AbstractDataTypes/MinMaxStackQueue/MinMaxStack.rb', line 26

def help
  self.help
end

#lengthObject



61
62
63
# File 'lib/zadt/AbstractDataTypes/MinMaxStackQueue/MinMaxStack.rb', line 61

def length
  @values.length
end

#maxObject



57
58
59
# File 'lib/zadt/AbstractDataTypes/MinMaxStackQueue/MinMaxStack.rb', line 57

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

#methodsObject



30
31
32
# File 'lib/zadt/AbstractDataTypes/MinMaxStackQueue/MinMaxStack.rb', line 30

def methods
  help
end

#minObject



53
54
55
# File 'lib/zadt/AbstractDataTypes/MinMaxStackQueue/MinMaxStack.rb', line 53

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

#peekObject



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

def peek
  @values.last[0]
end

#popObject



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

def pop
  @values.pop[0]
end

#push(val) ⇒ Object



34
35
36
37
38
39
40
41
42
43
# File 'lib/zadt/AbstractDataTypes/MinMaxStackQueue/MinMaxStack.rb', line 34

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



65
66
67
68
# File 'lib/zadt/AbstractDataTypes/MinMaxStackQueue/MinMaxStack.rb', line 65

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