mirror of
http://bgp.hk.skcks.cn:10086/https://github.com/krahets/hello-algo
synced 2026-04-20 21:00:58 +08:00
79 lines
1.7 KiB
Ruby
79 lines
1.7 KiB
Ruby
=begin
|
|
File: array_stack.rb
|
|
Created Time: 2024-04-06
|
|
Author: Xuan Khoa Tu Nguyen (ngxktuzkai2000@gmail.com)
|
|
=end
|
|
|
|
### Стек на основе массива ###
|
|
class ArrayStack
|
|
### Конструктор ###
|
|
def initialize
|
|
@stack = []
|
|
end
|
|
|
|
### Получить длину стека ###
|
|
def size
|
|
@stack.length
|
|
end
|
|
|
|
### Проверка, пуст ли стек ###
|
|
def is_empty?
|
|
@stack.empty?
|
|
end
|
|
|
|
### Помещение в стек ###
|
|
def push(item)
|
|
@stack << item
|
|
end
|
|
|
|
### Извлечение из стека ###
|
|
def pop
|
|
raise IndexError, 'стек пуст' if is_empty?
|
|
|
|
@stack.pop
|
|
end
|
|
|
|
### Доступ к верхнему элементу стека ###
|
|
def peek
|
|
raise IndexError, 'стек пуст' if is_empty?
|
|
|
|
@stack.last
|
|
end
|
|
|
|
### Вернуть список для вывода ###
|
|
def to_array
|
|
@stack
|
|
end
|
|
end
|
|
|
|
### Driver Code ###
|
|
if __FILE__ == $0
|
|
# Инициализация стека
|
|
stack = ArrayStack.new
|
|
|
|
# Помещение элемента в стек
|
|
stack.push(1)
|
|
stack.push(3)
|
|
stack.push(2)
|
|
stack.push(5)
|
|
stack.push(4)
|
|
puts "Стек stack = #{stack.to_array}"
|
|
|
|
# Доступ к верхнему элементу стека
|
|
peek = stack.peek
|
|
puts "Верхний элемент peek = #{peek}"
|
|
|
|
# Извлечение элемента из стека
|
|
pop = stack.pop
|
|
puts "Извлеченный элемент pop = #{pop}"
|
|
puts "stack после извлечения = #{stack.to_array}"
|
|
|
|
# Получение длины стека
|
|
size = stack.size
|
|
puts "Длина стека size = #{size}"
|
|
|
|
# Проверка на пустоту
|
|
is_empty = stack.is_empty?
|
|
puts "Пуст ли стек = #{is_empty}"
|
|
end
|