返回数组组合数组的函数

Tho*_*ggi 8 javascript arrays sorting probability

我正在尝试创建一个带有_.combinations三个参数的函数(下划线mixin)arr, pockets, duplicates.这是我设计用于展示行为应该如何的测试.

expect(_.combinations([1, 2], 1, false)).to.be.equal([[1],[2]])
expect(_.combinations([1, 2], 1, true)).to.be.equal([[1],[2]])
expect(_.combinations([1, 2, 3], 2, false)).to.be.equal([[1,2],[1,3],[2,3]])
expect(_.combinations([1, 2, 3], 2, true)).to.be.equal([[1,2],[1,3],[2,3],[2,1],[3,1],[3,2]])
expect(_.combinations([1, 2, 3, 4], 3, false)).to.be.equal([[1,2,3],[1,2,4],[1,3,4],[2,1,4],[2,3,4],[3,4,1]])
expect(_.combinations([1, 2, 3, 4], 3, true)).to.be.equal([[1,2,3],[1,2,4],[1,3,4],[2,1,4],[2,3,1],[2,3,4],[3,1,2],[3,4,1],[3,4,2],[4,1,2],[4,1,3],[4,2,3]])
Run Code Online (Sandbox Code Playgroud)

在我去创建这个函数之前,我想知道它是否已经存在于库中.也许这个特定的功能已经有了一个我不熟悉的名字.

那里有什么东西吗?

Pra*_*vin 6

这个库功能很好.我认为它几乎得到了你所需要的东西.

var combinatorics=require('/path/to/combinatorics');

var a = [1,2,3];

var ans1=combinatorics.permutation(a,2); 
console.log(ans1.toArray());// [[1,2],[2,1],[1,3],[3,1],[2,3],[3,2]] like when duplicates is set to true


var ans2=combinatorics.combination(a,2); 
console.log(ans2.toArray());//[[1,2],[2,1],[1,3],[3,1],[2,3],[3,2]] like when duplicates is set to false
Run Code Online (Sandbox Code Playgroud)