程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> 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。

    1. 上一頁:
    2. 下一頁:
    Copyright © 程式師世界 All Rights Reserved