Ruby: Массивы

Массивы в Ruby работают также, как и массивы в любых других динамических языках. Отличия, в основном, в некоторых синтаксических конструкциях и большом количестве встроенных методов. Основные операции:

items = [1, 2]

# Добавление в конец
items << 3 # [1, 2, 3]
# Добавление в начало
items.unshift 5 # [5, 1, 2, 3]

items.first # 5
# Последний элемент
items.last # 3

items.length # 4
# не пустой?
items.any? # true
# пустой?
items.empty? # false

# входит ли value в items
items.include? value

# Обращение к несуществующему элементу возвращает nil
items[5] # nil

items.sum # 11

Массивы в Ruby передаются по ссылке, как в Python и JavaScript. Но в отличии от последних, сравнение массивов идет по значениям:

items = [1, 2]
items == [1, 2] # true

Для обхода массивов в Ruby используется метод each(). По принципу работы он похож на times(), но применяется к коллекциям. each() принимает блок, который, затем, вызывается для каждого элемента коллекции. Внутрь блока передается текущий элемент.

# Сбор в строчку
items = [1, 2, 3]
result = ''
items.each do |item|
  result = "#{result}#{item}"
end
puts result # => '123'

Задание

Напишите функцию, которая находит пересечение двух массивов. Под пересечением понимается новый массив, который состоит из элементов входящих одновременно в оба исходных массива:

intersection([1, 3, 8], [9, 3, 1]); # [3, 1]
intersection([8], [5, 0]) # []

Советы


Нашли ошибку? Есть что добавить? Пулреквесты приветствуются https://github.com/hexlet-basics
Если вы столкнулись с трудностями и не знаете, что делать, задайте вопрос в нашем большом и дружном сообществе
Упражнение доступно только авторизованным пользователям.

Пожалуйста, авторизуйтесь, это необходимо для отслеживания прогресса выполнения уроков. Если у вас ещё нет учётной записи, то сейчас самое время создать аккаунт.