在 Clojure 中,矩阵的可能表示是向量的向量,即[[1 2] [3 4]]
。转置矩阵的可能实现是:
(defn transpose [matrix]
(loop [matrix matrix, transp [], i 0]
(if (< i (count (nth matrix 0)))
(recur matrix
(conj transp
(vec (reduce concat
(map #(conj [] (nth %1 i))
matrix))))
(inc i))
transp)))
谁能想到一个更惯用的 Clojure 实现?例如,为了避免这种可怕的循环再次发生?