2
我想實現「縮小地圖」功能。也就是說,它應該返回由施加f
到第一2項的coll
的結果的序列,隨後施加f
該搜索結果和在coll
第三項的結果,等等如何實現懶惰的「縮小地圖」功能?
(def c [[0 0 0 0] [1 0 0 0] [0 1 0 0] [0 0 1 0] [0 0 0 1]])
(defn- sum-vector [v1 v2]
(map + v1 v2))
(defn reduce-map [f coll & acc]
(if (< (count coll) 2)
(if (empty? acc) coll acc)
(let [head (apply f (take 2 coll))
tail (drop 2 coll)]
(recur f (conj tail head) (conj acc head)))))
對於例如,調用這個函數是這樣的:
(reduce-map sum-vector c)
應該返回:
[[1 0 0 0] [1 1 0 0] [1 1 1 0] [1 1 1 1]]
(實際上,它也許應該返回未修改的第一個項目爲好,更好地模擬map
,但後來我可以修復)
權,現在,這是它返回:
((1 1 1 1) (1 1 1 0) (1 1 0 0) (1 0 0 0))
我如何「推「在(紐約)seq結束?
如果我代替reduce-map
爲recur
,這是它返回:
(((1 1 1 1) ((1 1 1 0) ((1 1 0 0) ((1 0 0 0))))))
是在什麼上面我的代碼recur
和真正的遞歸之間的區別?
而且,是否有內置的,或更好的,或更習慣的方法來實現reduce-map
?
最後,我想輸出序列是懶惰的。我只是將整個東西包裝在lazy-seq
?
那麼*快*。謝謝! – 2010-11-23 10:02:21