如何将Haskell中的Integer转换成String和String转换成Integer?
How to convert Integer in String and String in Integer in Haskell?
我还在学习 Haskell,我对这门语言真的很困惑...我必须实现两个函数 fromInteger :: Integer -> String
和 toInteger :: String -> Integer
在 [=18] 之间进行翻译=] 整数和数字按相反顺序的数字串排列,如:"25" -> "52"
。为了功能分解,我应该首先实现 fromDigit :: Integer -> Char
和 toDigit :: Char -> Integer
在数字和字符之间转换。
这个函数应该是什么样子的?
非常感谢!
您可以使用 read :: Read a => String -> a
and show :: Show a => a -> String
从 Integer
转换为 String
:
Prelude> show 52
"52"
Prelude> read "52" :: Integer
52
但是您不需要将值转换为字符串来反转数字的顺序。您可以使用递归和 quotRem :: Integral a => a -> a -> (a, a)
来获得商和余数。
您还可以使用递归将 Integer
转换为 String
。这里我们使用累加器 a String
,每次计算最后一位。因此看起来像:
fromInteger :: Integer -> String
fromInteger = go []
where go ls x | x <= 9 = … : …
| otherwise = go (… : ls) …
where (q, r) = quotRem x 10
您还需要填写 …
部分。
我还在学习 Haskell,我对这门语言真的很困惑...我必须实现两个函数 fromInteger :: Integer -> String
和 toInteger :: String -> Integer
在 [=18] 之间进行翻译=] 整数和数字按相反顺序的数字串排列,如:"25" -> "52"
。为了功能分解,我应该首先实现 fromDigit :: Integer -> Char
和 toDigit :: Char -> Integer
在数字和字符之间转换。
这个函数应该是什么样子的?
非常感谢!
您可以使用 read :: Read a => String -> a
and show :: Show a => a -> String
从 Integer
转换为 String
:
Prelude> show 52
"52"
Prelude> read "52" :: Integer
52
但是您不需要将值转换为字符串来反转数字的顺序。您可以使用递归和 quotRem :: Integral a => a -> a -> (a, a)
来获得商和余数。
您还可以使用递归将 Integer
转换为 String
。这里我们使用累加器 a String
,每次计算最后一位。因此看起来像:
fromInteger :: Integer -> String
fromInteger = go []
where go ls x | x <= 9 = … : …
| otherwise = go (… : ls) …
where (q, r) = quotRem x 10
您还需要填写 …
部分。