本文實例講述了PHP實現(xiàn)數(shù)組的笛卡爾積運算。分享給大家供大家參考,具體如下:
數(shù)組的笛卡爾積在實際中還是挺有用處的,比如計算商品的規(guī)格時就經(jīng)常用到,下面寫一種實現(xiàn)方式,如下代碼
$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;
}
以上例子輸出的結(jié)果如下:
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
)
)
如果需要輸出字符串形式的結(jié)果可以把代碼改成這樣
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;
}
輸出結(jié)果如下所示:
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
)
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《PHP數(shù)學(xué)運算技巧總結(jié)》、《PHP運算與運算符用法總結(jié)》、《php字符串(string)用法總結(jié)》、《PHP數(shù)組(Array)操作技巧大全》、《PHP常用遍歷算法與技巧總結(jié)》、《PHP數(shù)據(jù)結(jié)構(gòu)與算法教程》、《php程序設(shè)計算法總結(jié)》、《php正則表達式用法總結(jié)》及《php常見數(shù)據(jù)庫操作技巧匯總》
希望本文所述對大家PHP程序設(shè)計有所幫助。
您可能感興趣的文章:- PHP實現(xiàn)笛卡爾積算法的實例講解
- PHP笛卡爾積實現(xiàn)算法示例
- PHP基于自定義函數(shù)生成笛卡爾積的方法示例
- php計算多個集合的笛卡爾積實例詳解
- PHP基于進程控制函數(shù)實現(xiàn)多線程
- PHP如何防止用戶重復(fù)提交表單
- Nginx+php配置文件及原理解析
- thinkphp諸多限制條件下如何getshell詳解
- PHP笛卡爾積實現(xiàn)原理及代碼實例