test n = (sum s)*4+2*(n-1)*((l')^2)-2*(n-1)*(l')
where
p =sort $[ m | a<-[1..(n-1)],b<-[1..(n-1)],let m= (b/a), (a^2+b^2< (n^2))]
l'= length p
s = (product a) : next a (group p)
where
a = [(n-1),2*(l')+(n-2)]
next [x,y] (z:z':zs) = case (null zs) of
False -> (x')*(y')*l : next [x',y'] (z':zs)
True -> (x')*(y')*l :[]
where
l = length z
x' = x+l
y' = y-length z'
为什么上面的代码会出现以下错误:
使用'/'时没有(Fractional Int)的实例 在表达式中:(b / a)
在'm'的等式中:m =(b / a)
在'($)'的第二个参数中,即
‘[m | a <- [1 .. (n - 1)], b <- [1 .. (n - 1)], let m = (b / a), (a ^ 2 + b ^ 2 < (n ^ 2))]’
但是当我手动替换代码中的n=3
时:
test' = (sum s)*4+2*(3-1)*((l')^2)-2*(3-1)*(l')
where
p = sort $[ m | a<-[1..(3-1)],b<-[1..(3-1)],let m= (b/a), (a^2+b^2< (3^2))]
l'= length p
s = (product a) : next a (group p)
where
a = [(3-1),2*(l')+(3-2)]
next [x,y] (z:z':zs) = case (null zs) of
False -> (x')*(y')*l : next [x',y'] (z':zs)
True -> (x')*(y')*l :[]
where
l = length z
x' = x+l
y' = y-length z'
然后它可以在GHCi中运行;发生了什么事?
答案 0 :(得分:3)
当您输入n
时,您强制它与您的表达式成为Int
。因此,b
和a
变为Int
,这在a/b
中成了问题。
当您编写3
时,多边形文字允许某些表达式使用Int
,而某些表达式则使用其他Fractional a => a
。在该函数中使用的3
只是不同的值。
创建一个不同的值,例如nP = fromIntegral n
should allow you to use n in every context,因为nP
不应该被任何表达式强化。