1

我正在尝试在 SML 中编写一个函数来计算交替谐波级数的部分和,而对于我来说,我无法弄清楚为什么编译器说其中一种情况是多余的。我以前没有使用过 case 语句(或本地的,就此而言),但这些 case 的顺序对我来说似乎是正确的。

local
  fun altHarmAux (x:int, y:real) =
    case x of
          1      => 1.0
         | evenP => altHarmAux(x-1, y - y/(real x))
         | oddP  => altHarmAux(x-1, y + y/(real x))
in
fun altHarmonic (a:int) = altHarmAux(a, real a)
end
4

1 回答 1

3

即使您在某处定义了这两个谓词函数,它们也不能在这种情况下使用。

无论您在 => 左侧写什么,都将绑定到您要匹配的值,因此您的案例中的最后两个匹配项将匹配相同的输入,使最后一个匹配项无用,因为始终使用第一个匹配项

您必须将谓词函数直接应用于值,然后匹配结果

local
  fun altHarmAux (x, y) =
    case (x, evenP x) of
         (1, _)     => 1.0
       | (_ true)   => altHarmAux(x-1, y - y/(real x))
       | (_, false) => altHarmAux(x-1, y + y/(real x))
in
fun altHarmonic a = altHarmAux(a, real a)
end

或者更简单

local
  fun altHarmAux (1, _) = 1.0
    | altHarmAux (x, y) =
        altHarmAux (x-1, y + (if evenP x then ~y else y) / (real x))
in
  fun altHarmonic a = altHarmAux (a, real a)
end

或者

local
  fun altHarmAux (1, _) = 1.0
    | altHarmAux (x, y) =
        if evenP x then
          altHarmAux (x-1, y - y/(real x))
        else
          altHarmAux (x-1, y + y/(real x))
in
  fun altHarmonic a = altHarmAux (a, real a)
end
于 2013-09-15T20:23:19.237 回答