萬盛學電腦網

 萬盛學電腦網 >> 網絡編程 >> php編程 >> PHP中排列組合及性能對比

PHP中排列組合及性能對比

   排列組合公式/排列組合計算公式公式P是指排列,從N個元素取R個進行排列。 公式C是指組合,從N個元素取R個,不進行排列了,但在php中我們可以用N種方法寫出來了,但每一種寫法的性能會不同,下面我們就來看看吧。

  需求是這樣的:

  找到數組中所有可能的指定長度的組合,要求沒有重復。

  方法一:

代碼如下  

function getCombinationToString($arr,$m){
$result = array();
if ($m ==1){
return $arr;
}

if ($m == count($arr)){
$result[] = implode(',' , $arr);
return $result;
}

$temp_firstelement = $arr[0];
unset($arr[0]);
$arr = array_values($arr);
$temp_list1 = getCombinationToString($arr, ($m-1));

foreach ($temp_list1 as $s){
$s = $temp_firstelement.','.$s;
$result[] = $s;
}
unset($temp_list1);

$temp_list2 = getCombinationToString($arr, $m);
foreach ($temp_list2 as $s){
$result[] = $s;
}
unset($temp_list2);

return $result;
}
$arr = array(1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18);
$t = getCombinationToString($arr, 6);

var_dump($t);

  執行時間:238ms。

  方法二:

代碼如下  

function getCombinAryByNum( $arr, $num,$t=array()) {
if ($num == 0) {
return array($t);
}
$r = array();
for ($i=0,$l=count($arr); $i <= $l-$num; $i++) {
$tmp = getCombinAryByNum( array_slice($arr, $i+1, $l, false), $num-1,array_merge($t, array($arr[$i])));
$r = array_merge($r, $tmp);
}
return $r;
}

$arr = array(1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18);
$numum = 6;
$ss = getCombinAryByNum($arr,$numum);

var_dump($ss);

  執行時間:710ms。

copyright © 萬盛學電腦網 all rights reserved