gpt4 book ai didi

haskell - Haskell 中的反向函数行为

转载 作者:行者123 更新时间:2023-12-05 08:45:30 27 4
gpt4 key购买 nike

digits :: Int -> [Int]
digits n = reverse (x)
where x
| n < 10 = [n]
| otherwise = (mod n 10) : (digits (div n 10))
*ghci> digits 1234 = [3,1,2,4]*
digits' :: Int -> [Int]
digits' n = (x)
where x
| n < 10 = [n]
| otherwise = (mod n 10) : (digits' (div n 10))
*ghci>digits' 1234 = [4,3,2,1]*

根据我的理解,digits 1234 的计算应该是 [1,2,3,4]。但似乎我错过了什么。谁能解释一下?

最佳答案

问题是 digits 在每次递归调用中都会反转字符串,而不仅仅是在外层一次。试试 digits x = reverse (digits' x)(或者,等价地,digits = reverse .digits'),看看你能否解释其中的区别。

关于haskell - Haskell 中的反向函数行为,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/72441692/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com