笛卡尔积 php,PHP笛卡尔积实现算法示例

笛卡尔积 php,PHP笛卡尔积实现算法示例本文实例讲述了PHP笛卡尔积实现算法。分享给大家供大家参考,具体如下:$arr=array(array(1,3,4,5),array(3,5,7,9),array(76,6,1,0));/****实现二维数组的笛卡尔积组合**$arr要进行笛卡尔积的二维数组**$str最终实现的笛卡尔积组合,可不写**@returnarray**/functioncartesian($arr,…

大家好,又见面了,我是你们的朋友全栈君。

本文实例讲述了PHP笛卡尔积实现算法。分享给大家供大家参考,具体如下:

$arr = array(array(1,3,4,5),array(3,5,7,9),array(76,6,1,0));

/**

** 实现二维数组的笛卡尔积组合

** $arr 要进行笛卡尔积的二维数组

** $str 最终实现的笛卡尔积组合,可不写

** @return array

**/

function cartesian($arr,$str = array()){

//去除第一个元素

$first = array_shift($arr);

//判断是否是第一次进行拼接

if(count($str) > 1) {

foreach ($str as $k => $val) {

foreach ($first as $key => $value) {

//最终实现的格式 1,3,76

//可根据具体需求进行变更

$str2[] = $val.’,’.$value;

}

}

}else{

foreach ($first as $key => $value) {

//最终实现的格式 1,3,76

//可根据具体需求进行变更

$str2[] = $value;

}

}

//递归进行拼接

if(count($arr) > 0){

$str2 = cartesian($arr,$str2);

}

//返回最终笛卡尔积

return $str2;

}

$cartesian_product = cartesian($arr);

print_r($cartesian_product);

?>

最终输出格式

Array

(

[0] => 1,3,76

[1] => 1,3,6

[2] => 1,3,1

[3] => 1,3,0

[4] => 1,5,76

[5] => 1,5,6

[6] => 1,5,1

[7] => 1,5,0

[8] => 1,7,76

[9] => 1,7,6

[10] => 1,7,1

[11] => 1,7,0

[12] => 1,9,76

[13] => 1,9,6

[14] => 1,9,1

[15] => 1,9,0

[16] => 3,3,76

[17] => 3,3,6

[18] => 3,3,1

[19] => 3,3,0

[20] => 3,5,76

[21] => 3,5,6

[22] => 3,5,1

[23] => 3,5,0

[24] => 3,7,76

[25] => 3,7,6

[26] => 3,7,1

[27] => 3,7,0

[28] => 3,9,76

[29] => 3,9,6

[30] => 3,9,1

[31] => 3,9,0

[32] => 4,3,76

[33] => 4,3,6

[34] => 4,3,1

[35] => 4,3,0

[36] => 4,5,76

[37] => 4,5,6

[38] => 4,5,1

[39] => 4,5,0

[40] => 4,7,76

[41] => 4,7,6

[42] => 4,7,1

[43] => 4,7,0

[44] => 4,9,76

[45] => 4,9,6

[46] => 4,9,1

[47] => 4,9,0

[48] => 5,3,76

[49] => 5,3,6

[50] => 5,3,1

[51] => 5,3,0

[52] => 5,5,76

[53] => 5,5,6

[54] => 5,5,1

[55] => 5,5,0

[56] => 5,7,76

[57] => 5,7,6

[58] => 5,7,1

[59] => 5,7,0

[60] => 5,9,76

[61] => 5,9,6

[62] => 5,9,1

[63] => 5,9,0

)

小编这里参考前面一篇《JavaScript笛卡尔积超简单实现算法》,给出一个php计算笛卡尔积的超简单算法示例如下:

function cartesian($arr1,$arr2){

$relarr = array();

foreach($arr1 as $v1){

foreach($arr2 as $v2){

array_push($relarr,$v1.”,”.$v2);

}

}

return $relarr;

}

//用法示例

$a = array(‘1′,’2′,’3’);

$b = array(‘a’,’b’,c);

print_r(cartesian($a,$b));

?>

运行结果:

Array

(

[0] => 1,a

[1] => 1,b

[2] => 1,c

[3] => 2,a

[4] => 2,b

[5] => 2,c

[6] => 3,a

[7] => 3,b

[8] => 3,c

)

希望本文所述对大家PHP程序设计有所帮助。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/157555.html原文链接:https://javaforall.net

(0)
上一篇 2022年7月11日 下午9:36
下一篇 2022年7月11日 下午9:36


相关推荐

  • java数组初始化赋值_Java数组的三种初始化方式

    java数组初始化赋值_Java数组的三种初始化方式Java 语言中数组必须先初始化 然后才可以使用 所谓初始化就是为数组的数组元素分配内存空间 并为每个数组元素附初始值 注意 数组完成初始化后 内存空间中针对该数组的各个元素就有个一个默认值 基本数据类型的整数类型 byte short int long 默认值是 0 基本数据类型的浮点类型 float double 默认值是 0 0 基本数据类型的字符类型 char 默认值是 u0000 基本数据

    2026年3月26日
    3
  • 火眼金睛审核 一键轻松处理[通俗易懂]

    火眼金睛审核 一键轻松处理——学籍助手简介学籍助手是专为河北省义务教育学籍管理系统区县端开发的一款辅助工具(图)。该工具不影响原系统正常使用,只是扩充了一些实用功能,只是让学籍管理变得异常轻松简单(如您不是区县学籍管理员,请勿下载)。学籍助手具有严格的入库审核、强大的批量处理和轻松的数据对接功能,犹如为原学籍管理系统赋予一双慧眼、插上一对翅膀,从容处理繁杂的学籍变…

    2022年4月13日
    52
  • GPT-5.4 正式发布后,普通开发者最该关注的不是更强,而是更稳、更省、更能接进工作流

    GPT-5.4 正式发布后,普通开发者最该关注的不是更强,而是更稳、更省、更能接进工作流

    2026年3月12日
    3
  • Monit:开源服务器监控工具

    Monit:开源服务器监控工具Monit 是一个跨平台的用来监控 Unix linux 系统 比如 Linux BSD OSX Solaris 的工具 Monit 特别易于安装 而且非常轻量级 只有 500KB 大小 并且不依赖任何第三方程序 插件或者库 Monit 可以监控服务器进程状态 HTTP TCP 状态码 服务器资源变化 文件系统变动等等 根据这些变化 可以设定邮件报警 重启进程或服务 易于安装 轻量级的实现以及强大的功能

    2026年3月19日
    1
  • JSONObject详解「建议收藏」

    JSONObject详解「建议收藏」JSONObject只是一种数据结构,可以理解为JSON格式的数据结构(key-value结构),可以使用put方法给json对象添加元素。JSONObject可以很方便的转换成字符串,也可以很方便的把其他对象转换成JSONObject对象。maven:<dependency> <groupId>org.json</groupId> <ar…

    2022年4月19日
    56
  • idea激活吗【2021免费激活】「建议收藏」

    (idea激活吗)2021最新分享一个能用的的激活码出来,希望能帮到需要激活的朋友。目前这个是能用的,但是用的人多了之后也会失效,会不定时更新的,大家持续关注此网站~IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/100143.html…

    2022年3月29日
    53

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号