Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Clojure - how to do reductions function but drop state?

Tags:

clojure

reduce

If I use the reductions function like so:

(reductions + [1 2 3 4 5])

Then I get

(1 3 6 10 15)

Which is great - but I'd like to apply a binary function in the same way without the state being carried forward - something like

(magic-hof + [1 2 3 4 5])

leads to

(1 3 5 7 9)

ie it returns the operation applied to the first pair, then steps 1 to the next pair.

Can someone tell me the higher-order function I'm looking for? (Something like reductions)

This is my (non-working) go at it:

(defn thisfunc [a b] [(+ a b) b])

(reduce thisfunc [1 2 3 4 5])
like image 775
hawkeye Avatar asked Dec 16 '13 13:12

hawkeye


2 Answers

You can do it with map:

(map f coll (rest coll))

And if you want a function:

(defn map-pairwise [f coll]
  (map f coll (rest coll)))

And if you really need the first element to remain untouched (thanx to juan.facorro's comment):

(defn magic-hof [f [x & xs :as s]]
  (cons x (map f s xs)))
like image 138
Leonid Beschastny Avatar answered Nov 11 '22 11:11

Leonid Beschastny


partition will group your seq:

user> (->> [1 2 3 4 5] (partition 2 1) (map #(apply + %)) (cons 1))
(1 3 5 7 9)
like image 29
edbond Avatar answered Nov 11 '22 12:11

edbond