首頁 >後端開發 >PHP問題 >php怎麼實現數組的笛卡爾積

php怎麼實現數組的笛卡爾積

藏色散人
藏色散人原創
2021-12-07 09:20:082137瀏覽

php實現陣列的笛卡爾積的方法:1、建立一個PHP範例檔案;2、定義一個陣列;3、透過「function dikaer($arr){...}」實作陣列的笛卡爾積運算即可。

php怎麼實現數組的笛卡爾積

本文操作環境:Windows7系統,PHP7.4版,Dell G3電腦。

php怎麼實現數組的笛卡爾積?

PHP實現數組的笛卡爾積運算範例

數組的笛卡爾積在實際中還是挺有用處的,例如計算商品的規格時就經常用到,下面寫一種實現方式,如下代碼

$arr = array(
  array(2),
  array(6,7),
  array('a','b','c')
);
function dikaer($arr){
 $arr1 = array();
 $result = array_shift($arr);
 while($arr2 = array_shift($arr)){
  $arr1 = $result;
  $result = array();
  foreach($arr1 as $v){
   foreach($arr2 as $v2){
    if(!is_array($v))$v = array($v);
    if(!is_array($v2))$v2 = array($v2);
    $result[] = array_merge_recursive($v,$v2);
   }
  }
 }
 return $result;
}

以上例子輸出的結果如下:

Array
(
  [0] => Array
    (
      [0] => 2
      [1] => 6
      [2] => a
    )
  [1] => Array
    (
      [0] => 2
      [1] => 6
      [2] => b
    )
  [2] => Array
    (
      [0] => 2
      [1] => 6
      [2] => c
    )
  [3] => Array
    (
      [0] => 2
      [1] => 7
      [2] => a
    )
  [4] => Array
    (
      [0] => 2
      [1] => 7
      [2] => b
    )
  [5] => Array
    (
      [0] => 2
      [1] => 7
      [2] => c
    )
)

如果需要輸出字串形式的結果可以把程式碼改成這樣

function dikaer($arr){
 $arr1 = array();
 $result = array_shift($arr);
 while($arr2 = array_shift($arr)){
  $arr1 = $result;
  $result = array();
  foreach($arr1 as $v){
   foreach($arr2 as $v2){
    $result[] = $v.','.$v2;
   }
  }
 }
 return $result;
}

輸出結果如下所示:

Array
(
  [0] => 2,6,a
  [1] => 2,6,b
  [2] => 2,6,c
  [3] => 2,7,a
  [4] => 2,7,b
  [5] => 2,7,c
)

推薦學習:《PHP影片教學

以上是php怎麼實現數組的笛卡爾積的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn