Haskell有一个takeUntil函数吗?

Cod*_*ice 12 haskell functional-programming

目前我正在使用

takeWhile (\x -> x /= 1 && x /= 89) l
Run Code Online (Sandbox Code Playgroud)

从列表中获取元素到1或89.但是,结果不包括这些sentinel值.Haskell是否有一个标准函数可以提供这种变体takeWhile,包括结果中的标记?到目前为止,我对Hoogle的搜索一直没有用.

Zet*_*eta 8

既然你问的是标准功能,没有.但是也没有包含a的包takeWhileInclusive,但这很简单:

takeWhileInclusive :: (a -> Bool) -> [a] -> [a]
takeWhileInclusive _ [] = []
takeWhileInclusive p (x:xs) = x : if p x then takeWhileInclusive p xs
                                         else []
Run Code Online (Sandbox Code Playgroud)

您需要做的唯一事情是获取值,无论谓词是否返回True并且仅使用谓词作为延续因子:

*Main> takeWhileInclusive  (\x -> x /= 20) [10..]
[10,11,12,13,14,15,16,17,18,19,20]
Run Code Online (Sandbox Code Playgroud)


san*_*inc 5

span你想要的吗?

matching, rest = span (\x -> x /= 1 && x /= 89) l
Run Code Online (Sandbox Code Playgroud)

然后看头部rest

  • 在这种情况下,我认为你需要 `span` 而不是 `break` 以符合 OP 的规范。 (2认同)