Clojure zipmap необходимо заполнить бланк
(testing "zipmap"
(is (= {:a 1 :b 2} (zipmap [:a :b] '(1 2))))
(is (= {3 1, 2 2, 1 3} (zipmap [1 2 3] [3 2 1])))
(is (= {} (zipmap [] [:a :b])))
(is (= {2 :b, 1 :a} (zipmap [1 2 3] [:a :b])))
Я решил топ 4 вопроса. Но я не мог понять последний. Нам нужно заполнить часть zipmap (я поставил там 2 знака вопроса). Вопрос в том, что нам нужно поместить туда, чтобы получить этот вывод:
{:list '() :map {} :vector [] :set #{}}
(is (= {:list '() :map {} :vector [] :set #{}} (zipmap ? ? )))))
Это на самом деле часть моей домашней работы, но я действительно хочу знать ответ.
Спасибо,
1 ответ
Решение
zipmap принимает две последовательности, одна из которых содержит все ключи, а другая содержит все значения. Он создает карту, где каждый ключ соответствует значению в той же позиции в другом списке
user> (zipmap [:list :map :vector :set] [`() {} [] #{}])
{:set #{}, :vector [], :map {}, :list ()}
В этом случае вас попросят предоставить последовательность ключевых слов и последовательность пустых примеров различных типов коллекций, чтобы создать карту ключевых слов для примера коллекции.