Replace individual list elements in Haskell?

后端 未结 9 680
死守一世寂寞
死守一世寂寞 2020-12-01 12:02

I have a list of elements and I wish to update them:

from this: [\"Off\",\"Off\",\"Off\",\"Off\"]

to this: [\"Off\",\"Off\",\"On\",\"Off\

9条回答
  •  予麋鹿
    予麋鹿 (楼主)
    2020-12-01 12:51

    Typically, you modify elements of a list by splitting the list, replacing an element, and joining it back together.

    To split a list at an index, we have:

     splitAt :: Int -> [a] -> ([a], [a]) 
    

    which you can use to break up a list, like so:

     > splitAt 2 ["Off","Off","Off","Off"] 
     (["Off","Off"],["Off","Off"])
    

    now you just need to pop the head element of the snd component of the list. This is easily done with pattern matching:

     > let (x,_:ys) = splitAt 2 ["Off","Off","Off","Off"]
     > x
     ["Off","Off"]
     > ys
     ["Off"]
    

    you can now join the list back together, with an "On":

     > x ++ "On" : ys
     ["Off","Off","On","Off"]
    

    I'll leave it to you to put those pieces together into a single function.


    As a style note, I'd suggest using a new custom data type, instead of String for your toggles:

     data Toggle = On | Off deriving Show
    

提交回复
热议问题