PHP中排列組合及性能對比
來源:易賢網(wǎng) 閱讀:611 次 日期:2015-01-08 15:57:13
溫馨提示:易賢網(wǎng)小編為您整理了“PHP中排列組合及性能對比”,方便廣大網(wǎng)友查閱!

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

需求是這樣的:

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

方法一:

代碼如下:

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);

執(zhí)行時間: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);

執(zhí)行時間:710ms。

更多信息請查看IT技術(shù)專欄

更多信息請查看網(wǎng)絡(luò)編程
易賢網(wǎng)手機網(wǎng)站地址:PHP中排列組合及性能對比

2025國考·省考課程試聽報名

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網(wǎng)安備53010202001879號 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)