用PHP组合数组,生成笛卡尔积的几个例子

1 下面的代码来生成笛卡尔积:

php 复制代码
function cartesianProduct($arrays) {
    $result = [[]];
    foreach ($arrays as $property => $property_values) {
        $tmp = [];
        foreach ($result as $result_item) {
            foreach ($property_values as $property_value) {
                $tmp[] = array_merge($result_item, [$property => $property_value]);
            }
        }
        $result = $tmp;
    }
    return $result;
}

$colors = ["红色", "白色", "黄色", "蓝色"];
$sizes = ["128G", "256G", "512G"];
$versions = ["国行", "港版", "美版", "韩版"];

// 生成笛卡尔积
$combinations = cartesianProduct([
    '颜色' => $colors,
    '尺寸' => $sizes,
    '版本' => $versions
]);

// 输出笛卡尔积结果
foreach ($combinations as $combination) {
    echo implode(', ', $combination) . "\n";
}

这段代码会生成由输入数组的笛卡尔积组成的数组。你可以根据需要修改输入数组,并按照相同的格式来调用cartesianProduct函数。

2 下面是使用嵌套循环生成笛卡尔积的PHP代码示例:

php 复制代码
// 定义多个数组
$colors = ['红色', '白色', '黄色', '蓝色'];
$capacities = ['128G', '256G', '512G'];
$versions = ['国行', '港版', '美版', '韩版'];

// 初始化笛卡尔积数组
$cartesianProduct = [];

// 使用嵌套循环生成笛卡尔积
foreach ($colors as $color) {
    foreach ($capacities as $capacity) {
        foreach ($versions as $version) {
            $cartesianProduct[] = [$color, $capacity, $version];
        }
    }
}

// 打印笛卡尔积
foreach ($cartesianProduct as $combination) {
    echo implode(', ', $combination) . "\n";
}

这将生成颜色、容量和版本的所有可能组合。你可以根据需要修改数组的值和数量来生成不同的笛卡尔积。此外,你还可以使用递归来处理不定数量的数组生成笛卡尔积。

3以下是一个示例,生成给定数组的笛卡尔积:

php 复制代码
function cartesianProduct($arrays) {
    $result = array();
    $max = count($arrays) - 1;
    $result = array();
    function helper($arr, $i) {
        global $result, $max;
        if ($i == $max) {
            foreach ($arr[$i] as $value) {
                $result[] = $value;
            }
        } else {
            foreach ($arr[$i] as $value) {
                helper($arr, $i + 1);
                foreach ($result as &$product) {
                    $product = "$product, $value";
                }
            }
        }
    }
    helper($arrays, 0);
    return $result;
}

// 示例用法
$colors = ["红色", "白色", "黄色", "蓝色"];
$storage = ["128G", "256G", "512G"];
$versions = ["国行", "港版", "美版", "韩版"];

$arrays = [$colors, $storage, $versions];
$cartesianProduct = cartesianProduct($arrays);

foreach ($cartesianProduct as $combination) {
    echo "组合: $combination\n";
}

这个示例将生成给定数组的笛卡尔积,以获取所有可能的组合。你可以根据你的需求替换 $colors$storage$versions 数组来生成不同的组合。

4 使用嵌套的循环来生成这些数组的笛卡尔积。以下是一些示例代码:

php 复制代码
// 示例1:生成颜色和尺寸的笛卡尔积
$colors = ["红色", "白色", "黄色", "蓝色"];
$sizes = ["128G", "256G", "512G"];

$combinations = [];
foreach ($colors as $color) {
    foreach ($sizes as $size) {
        $combinations[] = [$color, $size];
    }
}

print_r($combinations);

// 示例2:生成颜色、尺寸和版本的笛卡尔积
$colors = ["红色", "白色", "黄色", "蓝色"];
$sizes = ["128G", "256G", "512G"];
$versions = ["国行", "港版", "美版", "韩版"];

$combinations = [];
foreach ($colors as $color) {
    foreach ($sizes as $size) {
        foreach ($versions as $version) {
            $combinations[] = [$color, $size, $version];
        }
    }
}

print_r($combinations);

这些示例会生成颜色、尺寸和版本的笛卡尔积,你可以根据需要自定义数组和维度来生成不同组合。

相关推荐
我是唐青枫2 小时前
Php Doctrine ORM 实战详解:从实体映射到查询、关联与事务
php
juesdo2 小时前
array_search()函数的用法
web安全·php
ch3nyuyu6 小时前
socket套接字
开发语言·php
leagsoft_10038 小时前
零信任选型五刀法——零信任怎么选?五个问题,五条红线
开发语言·php
yyuuuzz9 小时前
云服务器软件部署的几个常见问题
运维·服务器·开发语言·网络·云计算·php·apache
juesdo9 小时前
青岑CTF web入门 EZCMD系列
web安全·网络安全·php
RisunJan9 小时前
Linux命令-php(PHP语言的命令行接口)
linux·php
艾莉丝努力练剑11 小时前
【Linux网络】NAT、内网穿透、内网打洞
linux·运维·服务器·网络·计算机网络·udp·php
dog2501 天前
网络长尾延时的重尾本质
开发语言·网络·php
其实防守也摸鱼1 天前
无线网络安全--10 规避WLAN验证之挫败MAC地址限制
网络·智能路由器·php·教程·虚拟机·wlan·无线网络安全