[英]Returning number of occurences with condition from list in Haskell
我想从列表中过滤数字,条件是它们必须小于 3,然后在起始列表中有多少这样的元素
filterLove :: (Num a, Ord a) => [a] -> Int
filterLove [42, 66, 15, 2] ~>* 1
我试过这个filterLove filter (< 3) a = length a
但它不起作用。 我不知道我该怎么做。 感谢帮助。
filterLove
是一个映射项目列表的函数,这意味着您可以将其定义为:
filterLove :: (Num a, Ord a) => [a] -> Int
filterLove xs = …
其中xs
是数字列表,而…
部分是一个类型应该为Int
的表达式。
因此,我们使用filter (<3) xs
创建一个仅包含小于 3 的xs
元素的新列表,其中filter :: (a -> Bool) -> [a] -> [a]
接受一个谓词和一个列表并生成一个包含满足谓词的所有元素的列表。 然后我们可以使用length (filter (<3) xs)
确定该列表的长度,其中length :: [a] -> Int
将确定列表的长度:
filterLove :: (Num a, Ord a) => [a] -> Int
filterLove xs = length (filter (<3) xs)
我们可以通过η-reduction删除参数xs
为:
filterLove :: (Num a, Ord a) => [a] -> Int
filterLove = length . filter (<3)
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.