haskell - 将字符串拆分为子字符串

标签 haskell

我想创建将字符串拆分为子字符串列表的函数,其中每个子字符串的长度为 k:

*Main> split_string_to_kmers "some_text" 3
["som","ome","me_","e_t","_te","tex","ext"]

这是我的解决方案:

split_string_to_kmers s k = split_string_to_kmers_helper s k []
    where split_string_to_kmers_helper [] k acc = acc
          split_string_to_kmers_helper s  k acc
            | length s >= k = split_string_to_kmers_helper (tail s) k (acc ++ [(take k s)])
            | otherwise = acc

我只是想知道是否有一种方法可以重写我的代码,使其更符合 haskell 的具体要求。

最佳答案

我猜这有点不同。

import Data.List (tails)

mySplit :: String -> Int -> [String]
mySplit str k = filter (\s -> length s == k) $ map (take k) (tails str)

您可以通过组合过滤器和 map 来提高效率。但这取决于您。

关于haskell - 将字符串拆分为子字符串,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19715157/

相关文章:

algorithm - 为什么骑士不覆盖所有的 table ?

haskell - "least"和 "greatest"在谈到定点时指的是什么顺序?

haskell - 如何将 Int 字段限制为某个值范围?

haskell - 如果一切都是不可变的,我们还需要互斥吗?

haskell - 除了模式之外,@在Haskell中还有什么意思?

haskell - Haskell 列表理解中的非详尽模式

haskell - 在 Haskell 的无点函数中理解 `ap`

haskell - 如何在资源有限的 Haskell 中解析大型 XML 文件?

haskell - () 在 Haskell 中是什么意思

haskell - 类型级 Peano 数和 UndecidableInstances