On Jun 8, 2014, at 3:12 PM, boz <b...@cox.net> wrote:

> Is there a better way to take this...
> 
>       [[:a [1 2]] 
>        [:b [3 4]]]
> 
> and convert it to this...
> 
>       [[:a 1] 
>        [:a 2] 
>        [:b 3] 
>        [:b 4]]
> 
> than using a loop like this...
> 
>       (defn doit [id v]
>         (loop [a (first v) r (rest v) result []]
>           (if a
>             (recur (first r) (rest r) (conj result [id a]))
>             result)))
> 
> ???

Lots of possibilities, and your loop doesn't look to me like it's handling the 
ids right, but FWIW I might do something like:

(defn split-key-pairs [grouped-data]
   (vec (apply concat (for [[key vals] grouped-data]
                        (for [v vals] [key v])))))

=> (split-key-pairs [[:a [1 2]] [:b [3 4]]])
[[:a 1] [:a 2] [:b 3] [:b 4]]

 -Lee

-- 
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
--- 
You received this message because you are subscribed to the Google Groups 
"Clojure" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to clojure+unsubscr...@googlegroups.com.
For more options, visit https://groups.google.com/d/optout.

Reply via email to