list - 生成列表的所有排列,包括不同大小和重复元素

标签 list haskell functional-programming permutation

我想创建函数 genAllSize::[a] -> [[a]],它接收一个列表 l 并生成所有按大小排序的列表可以用列表 l 的元素构建;即

> genAllSize [2,4,8] 
[[],[2],[4],[8],[2,2],[4,2],[8,2],[2,4],[4,4],[8,4],[2,8],[4,8],[8,8],[2,2,2],[4,2,2],[8,2,2], ...

你会怎么做?我想出了一个使用 Data.List 排列的解决方案,但我不想使用它。

最佳答案

  • 给定一个输入列表xs,以不确定的方式选择它的前缀
  • 对于前缀中的每个元素,以非确定性方式将其替换为 xs 的任何元素

结果:

> xs = [2,4,8]
> inits xs >>= mapM (const xs)
[[],[2],[4],[8],[2,2],[2,4],[2,8],[4,2],[4,4],[4,8],[8,2],[8,4],
[8,8],[2,2,2],[2,2,4],[2,2,8],[2,4,2],[2,4,4],[2,4,8],[2,8,2],
[2,8,4],[2,8,8],[4,2,2],[4,2,4],[4,2,8],[4,4,2],[4,4,4],[4,4,8],
[4,8,2],[4,8,4],[4,8,8],[8,2,2],[8,2,4],[8,2,8],[8,4,2],[8,4,4],
[8,4,8],[8,8,2],[8,8,4],[8,8,8]]

关于list - 生成列表的所有排列,包括不同大小和重复元素,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53157534/

相关文章:

python - 所有(2 ^ m−2)/2个可能的分区列表方式

C++链表创建——传入一个数组

haskell - 为什么在 Haskell 中编写函数时需要使用括号?

haskell - 为什么 Haskell 无法自动解析参数数量?

list - flutter : Unsupported operation: Cannot add to an unmodifiable list

python - 如何创建具有给定增量的数字范围

list - 如何对两个列表的元素求和。 haskell

swift - Swift 中奇怪的元组展开

list - 如何根据列表中的先前值过滤Haskell中的列表元素?

scala - Scala 标准 API 中的 IO Haskell Monad 等价物是什么?