折叠 Data.Map.adjust

Fold with Data.Map.adjust

我正在尝试获取正确的函数,该函数将通过遍历键列表来更新一个或多个值。

示例:

s1 = Data.Map.fromList [(1,"value1"), (2,"value2"), (3,"value3")]

通过将列表 [1,2] 和更新值 "plus" 传递给函数,列表应如下所示:

[(1,"plus"), (2,"plus"), (3,"value3")]

到目前为止,这是我尝试过的方法,我很难实现迭代要更新的键列表的函数

changeValue map newValue xs = foldr (\k map -> Map.adjust (newValue)(xs)(sm)) map m

我应该从那里寻找什么?我不认为我可以在这种情况下使用 map

好的,你走对了。

折叠确实是你需要的。您需要折叠键列表。起始值是您的原始地图,它在折叠过程中会发生变化。

您也正确识别了函数 adjust。

adjust 需要一个函数作为第一个参数。这个函数是\_ -> newValue,或者只是const newValue。我会远离使用名称 map,因为它可能会引起混淆。

经过这些更正后,您的程序可能看起来像这样:

import qualified Data.Map.Strict as M

s1 = M.fromList [(1,"value1"), (2,"value2"), (3,"value3")]

changeValue m newValue ks = foldr (\k m -> M.adjust (const newValue) k m) m ks

main :: IO ()
main = do
    print $ changeValue s1 "plus" [1, 2]