Какой идиоматический способ поменять два элемента в векторе - PullRequest
17 голосов
/ 12 мая 2011

Есть ли лучший или более краткий способ сделать следующее?

(defn swap [v i1 i2]
  "swap two positions in a vector"
  (let [e1 (v i1)
        e2 (v i2)]
       (-> (assoc v i1 e2)
       (assoc i2 e1))))

1 Ответ

33 голосов
/ 12 мая 2011

Не могу придумать и особенно элегантное решение.Вот как бы я написал это:

(defn swap [v i1 i2] 
   (asso­c v i2 (v i1) i1 (v i2)))­
...