Ben bir dizideki tüm karakterleri koymak ve kalan tüm karakterleri 'out şerit' bir özyinelemeli fonksiyon yazmak istiyorum. Dizi bir referans geçti dizi, boş ise.
<?php
$input = "hey";
function string_getpermutations($prefix, $characters, &$permutations)
{
if (count($characters) == 1)
$permutations[] = $prefix . array_pop($characters);
else
{
for ($i = 0; $i < count($characters); $i++)
{
$tmp = $characters;
unset($tmp[$i]);
string_getpermutations($prefix . $characters[$i], array_values($tmp), $permutations);
}
}
}
$characters = array();
for ($i = 0; $i < strlen($input); $i++)
$characters[] = $input[$i];
$permutations = array();
print_r($characters);
string_getpermutations("", $characters, $permutations);
print_r($permutations);
Çıkış yazdırır:
Array
(
[0] => h
[1] => e
[2] => y
)
Array
(
[0] => hey
[1] => hye
[2] => ehy
[3] => eyh
[4] => yhe
[5] => yeh
)
Ah yes,
combinations = order doens't matter.
permutations = order does matter.
Yani, hey, hye yeh hepsi aynı kombinasyonu olan, ancak söz konusu 3 ayrı permütasyon gibi. Öğelerin ölçek çok hızlı gider dikkat edin. Bu faktöryel denir ve 6 gibi yazılır! (6 karakter dizesi için) = 6 * 5 * 4 * 3 * 2 * 1 = 720 ürün. A 10 karakter dizesi 10 olacak! = Çok büyük bir dizidir zaten 3628800 permütasyon,. Bu örnekte 3 var! = 3 * = 6 2 * 1.