gpt4 book ai didi

if-statement - Elm - 每个 if 分支执行多行

转载 作者:行者123 更新时间:2023-12-05 00:13:31 24 4
gpt4 key购买 nike

例如,在一个分支中,我想查看一个数字可以被 1000 整除的次数,然后将减去该数量的起始数字递归地传递给函数。这是我写的:

if num // 1000 > 0 then
repeat (num // 1000) (String.fromChar 'M')
convertToRom (num % 1000)

但是,我在测试时在 REPL 中收到以下错误:

> getRomNums 3500
-- TYPE MISMATCH ----------------------------------------- .\.\RomanNumerals.elm

Function `repeat` is expecting 2 arguments, but was given 4.

34| repeat (num // 1000) (String.fromChar 'M')
35|> convertToRom (num % 1000)

Maybe you forgot some parentheses? Or a comma?

如何为单个 if 分支编写多行代码?

无关的旁注:格式系统使双斜线成为注释,但在 Elm 中双斜线是整数除法。不知道如何解决这个问题。

最佳答案

在 Elm(以及 Haskell 等其他函数式语言)中,您不会像在命令式语言中那样以迭代步骤编写代码。每个函数都必须返回一个值,每个逻辑分支都必须返回一个值。关于如何在 Elm 中“做多件事”没有单一的答案,但是使用 Elm 的类型系统、元组和递归,您会发现缺少命令式并不会真正阻止您做任何事情。这只是从以命令式风格编写代码的范式转变。

为了您编写罗马数字转换函数的目的,我认为直接的答案在于对结果使用显式递归和字符串连接:

convertToRom : Int -> String
convertToRom num =
if num // 1000 > 0 then
String.repeat (num // 1000) (String.fromChar 'M') ++ convertToRom (num % 1000)
else if ...
else
""

随着函数式编程工具集的增长,您会发现自己显式地使用递归的次数越来越少,而依赖于更高级别的抽象,如折叠和映射。

关于if-statement - Elm - 每个 if 分支执行多行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48508563/

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