комбинации с различной длиной и без повторов - PullRequest
1 голос
/ 02 января 2011

Кто-нибудь может предложить простой способ получения всех комбинаций без повторов и с различной длиной?

[0,1,2,3,4]

(2-е): [0,1], [0,2], [0,3] ... [3,4]

(3): [0,1,2], [0,1,3] ... [2,3,4]

(4): [0,1,2,3], [0,1,2,4] ... [1,2,3,4]

1 Ответ

2 голосов
/ 02 января 2011

заняло у меня некоторое время, но я думаю, что у меня это есть ...

здесь есть все комбинации без повторов

var arr:Array = [0, 1, 2, 3, 4];
var $allcombos:Array = [];
findCombos($allcombos,[],arr);

function findCombos($root:Array, $base:Array, $rem:Array):void {
    for (var i:int = 0; i < $rem.length; i++) {
        var a:Array = $base.concat();
        a.push($rem[i]);
        findCombos($root, a, $rem.slice(i + 1));
        if (a.length > 1) {
            $root.push(a);
        }
    }
}
...