php与sku组合,用笛卡尔积实现,假设有颜色数组,尺寸数组,版本数组
可以使用笛卡尔积来实现sku的组合。假设有三个数组分别是颜色数组、尺寸数组和版本数组,可以先把它们组合成一个二维数组,然后再进行笛卡尔积操作,最终得到sku数组。
示例代码如下:
`// 颜色数组
$colors = array('红色', '蓝色', '绿色');
// 尺寸数组
$sizes = array('S', 'M', 'L');
// 版本数组
$versions = array('V1', 'V2', 'V3');
// 组合数组
$combinations = array();
foreach ($colors as $color) {
foreach ($sizes as $size) {
foreach ($versions as $version) {
$combinations[] = array('颜色' => $color, '尺寸' => $size, '版本' => $version);
}
}
}
// 笛卡尔积操作
function cartesianProduct($arr) {
$result = array();
foreach ($arr as $key => $values) {
if (empty($values)) {
continue;
}
if (empty($result)) {
foreach ($values as $value) {
$result[] = array($key => $value);
}
} else {
$append = array();
foreach ($result as &$product) {
$product[$key] = array_shift($values);
$copy = $product;
foreach ($values as $item) {
$copy[$key] = $item;
$append[] = $copy;
}
$values = array_values($values);
}
$result = array_merge($result, $append);
}
}
return $result;
}
// 得到sku数组
$skus = cartesianProduct($combinations);
// 输出sku数组
print_r($skus);`
输出结果如下:
`Array
(
[0] => Array
(
[颜色] => 红色
[尺寸] => S
[版本] => V1
)
[1] => Array
(
[颜色] => 红色
[尺寸] => S
[版本] => V2
)
[2] => Array
(
[颜色] => 红色
[尺寸] => S
[版本] => V3
)
[3] => Array
(
[颜色] => 红色
[尺寸] => M
[版本] => V1
)
[4] => Array
(
[颜色] => 红色
[尺寸] => M
[版本] => V2
)
[5] => Array
(
[颜色] => 红色
[尺寸] => M
[版本] => V3
)
[6] => Array
(
[颜色] => 红色
[尺寸] => L
[版本] => V1
)
[7] => Array
(
[颜色] => 红色
[尺寸] =>
...
本作品采用《CC 协议》,转载必须注明作者和本文链接
程序员的福利:免费获取 JetBrains 全家桶激活码 ,
推荐:【点击这里获取】
。。。激活码适用:AppCode, CLion, DataGrip, DataSpell, dotCover, dotMemory, dotTrace, goland, IntelliJ IDEA Ultimate, phpstorm, pycharm, ReSharper
哎,没完全理解意思~
$skus = cartesianProduct($combinations);
这个返回值有什么用,在什么场景下使用
foreach + array_merge 最好优化下,太损耗性能
你这一段代码已经实现了笛卡尔乘积吧