I think this is indeed the best way to do this- On closer examination,
although there's some overhead in using "reductions" it appears to be
slower by only a constant factor- So with larger data sets it'll
retain a reasonable performance, same ball park as my tail-call
optimized versions.
On Dec 27, 8:52 pm, David Cabana <drcab...@gmail.com> wrote:
> Try this:
>
> (use '[clojure.contrib.seq-utils :only (reductions)])
>
> (defn left-total [lst]
>   (map vector lst
>                       (reductions + (cons 0 lst))))
>
>
>
> On Sun, Dec 27, 2009 at 8:36 PM, Conrad <drc...@gmail.com> wrote:
> > I've been writing Clojure code today and have noticed the same pattern
> > show up multiple times, but can't find an elegant way to code it in
> > idiomatic Clojure. I feel like I'm missing an obvious solution...
> > anyone else see something I don't? Thanks in advance!
>
> > The problem boils down to the following minimal example: Suppose you
> > want to write a function "left-total" which takes a list of number and
> > returns pairs of said numbers, along with the total of numbers to the
> > left:
>
> > => (left-total [3 5 10 1 2 7])
> > ([3 0] [5 3] [10 8] [1 18] [2 19] [7 21])
>
> > I can think of several ways to write this function. Three acceptable
> > versions of this function are written below, but all of them are
> > hideous looking. Is there a better solution? (Note that any solution
> > should avoid thrashing the stack or performing more than the minimum
> > number of additions.)

-- 
You received this message because you are subscribed to the Google
Groups "Clojure" group.
To post to this group, send email to clojure@googlegroups.com
Note that posts from new members are moderated - please be patient with your 
first post.
To unsubscribe from this group, send email to
clojure+unsubscr...@googlegroups.com
For more options, visit this group at
http://groups.google.com/group/clojure?hl=en

Reply via email to