metaclass: (Default)
[personal profile] metaclass
А вот как правильно сделать такую иммутабельную функциональную структуру данных:

есть словарь(map) из строк в качестве ключей и некоей структуры в качестве значений. Причем эта структура содержит внутри себя список. Для простоты можно считать что структура и есть просто список.
И задача - заполнить оный словарь имея список пар "строка-ключ, значение для списка". Ключи в списке пар повторяются. Короче, что-то вроде "select key,list(value) from KeyValuePairs group by key".

Наверно, можно предварительно отсортировать список по ключам, затем просто пройтись по списку, объединяя списки пар с одинаковыми ключами в пару "ключ, список значений" и полученное затем засунуть в словарь.

Date: 2010-09-09 08:50 pm (UTC)
From: [identity profile] permea-kra.livejournal.com
foldl M.empty (M.unionWith (++)) . map ( uncarry M.singleton )

Date: 2010-09-09 08:54 pm (UTC)
From: [identity profile] http://users.livejournal.com/_slw/
у меня лаконичней

Date: 2010-09-09 08:55 pm (UTC)
From: [identity profile] permea-kra.livejournal.com
У вас нечитаемый asii-арт.

Date: 2010-09-09 08:57 pm (UTC)
From: [identity profile] http://users.livejournal.com/_slw/
не более вашего

Date: 2010-09-09 08:56 pm (UTC)
From: [identity profile] permea-kra.livejournal.com
И половина мысли, насколько я вижу

Date: 2010-09-09 08:59 pm (UTC)
From: [identity profile] http://users.livejournal.com/_slw/
ровно та половина, на которую хватило ТЗ

Profile

metaclass: (Default)
metaclass

April 2017

S M T W T F S
      1
2345678
9101112 131415
16171819202122
23242526272829
30      

Most Popular Tags

Style Credit

Expand Cut Tags

No cut tags
Page generated Aug. 26th, 2025 04:13 pm
Powered by Dreamwidth Studios