作为函数输入的字符串的Haskell函数头

问题描述 投票:0回答:1

我正在Haskell中创建一个Enigma机器,并且我对以下代码有疑问:

encrypt :: String -> [String] -> String
encrypt t [d1, d2, d3]
  | length t > 1 = encryptOne head t [d1, d2, d3] ++ encrypt (tail t) [d1, d2, rotateF d3]
  | length t == 1 = encryptOne head t [d1, d2, d3]
  | otherwise = ""

加密函数采用字符串,并使用encryptOne函数递归求解每个字符。每次迭代时,都使用rotateF功能旋转转子(早期阶段,仍在解决此问题)。 encryptOne函数如下所示:

encryptOne :: Char -> [String] -> Char

问题是encryptOnet [d1, d2, d3]部分,其中无法解决头t,并且发生以下错误

    length t == 1 = encryptOne head t [d1, d2, d3]
                               ^^^^
    * Couldn't match type `Char' with `[Char]'
      Expected type: [String]
        Actual type: String

有人知道如何重构此部分,以便头t返回要在encryptOne中使用的字符吗?

haskell higher-order-functions head
1个回答
0
投票

感谢威廉,我使用括号找到了第一个问题。

第二个问题是关于encryptOne的类型问题。我现在将其添加到问题中,它表明它正在返回Char,而crypto函数返回String。我必须将encryptOne的结果从Char转换为String才能解决:

charToString :: Char -> String
charToString c = [c]
© www.soinside.com 2019 - 2024. All rights reserved.