4
arrayの要素からすべての順列を取得したいと考えています。ソース配列は非常に簡単です:ヒープのアルゴリズムで重複が発生する理由
$arr = [ 1,2,3,4 ];
私は、私が理解する助けてください作品の結果が重複
array (size=24)
0 => '1-2-3-4' << same 4
1 => '2-1-3-4' << same 5
2 => '3-2-1-4'
3 => '2-3-1-4'
4 => '1-2-3-4' << same 0
5 => '2-1-3-4' < same 1
6 => '4-2-3-1'
7 => '2-4-3-1'
8 => '3-2-4-1'
9 => '2-3-4-1'
10 => '4-2-3-1'
11 => '2-4-3-1'
12 => '4-1-3-2'
13 => '1-4-3-2'
14 => '3-1-4-2'
15 => '1-3-4-2'
16 => '4-1-3-2'
17 => '1-4-3-2'
18 => '4-1-2-3'
19 => '1-4-2-3'
20 => '2-1-4-3'
21 => '1-2-4-3'
22 => '4-1-2-3'
23 => '1-4-2-3'
の多くを持っている
private function mixture($size, array $collection) {
$permutations = [];
$offset = $size - 1;
if (1 === $size) {
$permutations[] = implode('-', $collection);
return $permutations;
}
for ($i = 0; $i < $offset; $i++) {
$permutations = array_merge($permutations, $this->mixture($offset, $collection));
$j = (0 == $size % 2) ? $i : 0;
$tmp_el = $collection[ $offset ];
$collection[ $offset ] = $collection[ $j ];
$collection[ $j ] = $tmp_el;
}
$permutations = array_merge($permutations, $this->mixture($offset, $collection));
return $permutations;
}
、Heap's algorithmを実装するためのコードを書きましたこれを理由にコードを修正してください。私は結果から重複を取り除きたい。 おかげ
@Dukeling、PHPはプログラミング言語です。数秒前に質問に適切なタグを追加しました –