2
No instance for (Fractional Int) arising from a use of `leap'
Possible fix: add an instance declaration for (Fractional Int)
In the first argument of `(==)', namely `leap (x)'
In the second argument of `(&&)', namely `leap (x) == 1'
In the expression: (y == 2) && leap (x) == 1

在 ghci 中加载文件时出现此错误

这是导致错误的函数

daysInMonth :: Int -> Int -> Int
daysInMonth y x
    | (y == 1 || y == 3 || y == 5 || y == 7 || y == 8 || y == 10 || y == 12) = 31
    | (y == 4 || y == 6 || y == 9 || y == 11) = 30
    | (y == 2) && leap(x) == 1 = 28
    | (y == 2) && leap(x) == 0 = 29
    where
    leap a = if (a / 4) == 0 then return 1 else return 0
4

1 回答 1

3

您正在尝试计算(仅等于a / 4, an )是 an 的位置。该类型不属于类型类,因此没有为s 定义。为了做你想做的事,你可以:axIntIntIntFractional/Int

  1. 通过写入转换a为类型Fractionalif fromIntegral a / 4 == 0 then ...

  2. 或者,如果你想做“整数除法”并丢弃余数,写if quot a 4 == 0 then ...

此外,return在 Haskell 中与return其他语言不同。在这里摆脱它。

(此外,这不是您确定闰年的方式。)

于 2013-10-28T21:04:07.387 回答