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