PHP实现笛卡尔积算法的实例讲解


Posted in PHP onDecember 22, 2019

概念

在数学中,两个集合X和Y的笛卡儿积(Cartesian product),又称直积,表示为 X × Y。设A、B是任意两个集合,在集合A中任意取一个元素x,在集合B中任意取一个元素y,组成一个有序对(x,y),把这样的有序对作为新的元素,他们的全体组成的集合称为集合A和集合B的直积,记为A×B,即 A×B={(x,y)|x∈A且y∈B}。

假设集合 A={a, b},集合 B={0, 1, 2},则两个集合的笛卡尔积为 {(a, 0), (a, 1), (a, 2), (b, 0), (b, 1), (b, 2)}。

举例

给出三个域:

D1 = { 张清玫,刘逸 }

D2 = {计算机专业,信息专业}

D3 = {李勇,刘晨,王敏}

则 D1,D2,D3 的笛卡尔积 D = D1×D2×D3,等于:

{

  (张清玫, 计算机专业, 李勇),

  (张清玫, 计算机专业, 刘晨),

  (张清玫, 计算机专业, 王敏),

  (张清玫, 信息专业, 李勇),

  (张清玫, 信息专业, 刘晨),

  (张清玫, 信息专业, 王敏),

  (刘逸, 计算机专业, 李勇),

  (刘逸, 计算机专业, 刘晨),

  (刘逸, 计算机专业, 王敏),

  (刘逸, 信息专业, 李勇),

  (刘逸, 信息专业, 刘晨),

  (刘逸, 信息专业, 王敏)

}

这样就把D1、D2、D3这三个集合中的每个元素加以对应组合,形成庞大的集合群。本个例子中的D中就会有 2X2X3=12 个元素,如果一个集合有1000个元素,有这样3个集合,他们的笛卡尔积所组成的新集合会达到十亿个元素。假若某个集合是无限集,那么新的集合就将是有无限个元素。

PHP代码 - 输出数组形式

function Descartes()

{

  $t = func_get_args();                  // 获取传入的参数

  if (func_num_args() == 1) {                // 判断参数个数是否为1

    return call_user_func_array(__FUNCTION__, $t[0]); // 回调当前函数,并把第一个数组作为参数传入

  }

  $a = array_shift($t);    // 将 $t 中的第一个元素移动到 $a 中,$t 中索引值重新排序

  if ( !is_array($a)) {

    $a = [$a];

  }

  $a = array_chunk($a, 1);   // 分割数组 $a ,为每个单元1个元素的新数组

  do {

    $r = [];

    $b = array_shift($t);

    if ( !is_array($b)) {

      $b = [$b];

    }

    foreach ($a as $p) {

      foreach (array_chunk($b, 1) as $q) {

        $r[] = array_merge($p, $q);

      }

    }

    $a = $r;

  } while ($t);

  return $r;

}

使用:

$arr = [

  [

    '张清玫',

    '刘逸'

  ],

  [

    '计算机专业',

    '信息管理与信息系统专业',

    '电子商务专业'

  ],

  [

    '2018级',

    '2017级'

  ]

];

$r = Descartes($arr);

效果:

array(12) {

 [0]=>

 array(3) {

  [0]=>

  string(9) "张清玫"

  [1]=>

  string(15) "计算机专业"

  [2]=>

  string(7) "2018级"

 }

 [1]=>

 array(3) {

  [0]=>

  string(9) "张清玫"

  [1]=>

  string(15) "计算机专业"

  [2]=>

  string(7) "2017级"

 }

 [2]=>

 array(3) {

  [0]=>

  string(9) "张清玫"

  [1]=>

  string(33) "信息管理与信息系统专业"

  [2]=>

  string(7) "2018级"

 }

 [3]=>

 array(3) {

  [0]=>

  string(9) "张清玫"

  [1]=>

  string(33) "信息管理与信息系统专业"

  [2]=>

  string(7) "2017级"

 }

 [4]=>

 array(3) {

  [0]=>

  string(9) "张清玫"

  [1]=>

  string(18) "电子商务专业"

  [2]=>

  string(7) "2018级"

 }

 [5]=>

 array(3) {

  [0]=>

  string(9) "张清玫"

  [1]=>

  string(18) "电子商务专业"

  [2]=>

  string(7) "2017级"

 }

 [6]=>

 array(3) {

  [0]=>

  string(6) "刘逸"

  [1]=>

  string(15) "计算机专业"

  [2]=>

  string(7) "2018级"

 }

 [7]=>

 array(3) {

  [0]=>

  string(6) "刘逸"

  [1]=>

  string(15) "计算机专业"

  [2]=>

  string(7) "2017级"

 }

 [8]=>

 array(3) {

  [0]=>

  string(6) "刘逸"

  [1]=>

  string(33) "信息管理与信息系统专业"

  [2]=>

  string(7) "2018级"

 }

 [9]=>

 array(3) {

  [0]=>

  string(6) "刘逸"

  [1]=>

  string(33) "信息管理与信息系统专业"

  [2]=>

  string(7) "2017级"

 }

 [10]=>

 array(3) {

  [0]=>

  string(6) "刘逸"

  [1]=>

  string(18) "电子商务专业"

  [2]=>

  string(7) "2018级"

 }

 [11]=>

 array(3) {

  [0]=>

  string(6) "刘逸"

  [1]=>

  string(18) "电子商务专业"

  [2]=>

  string(7) "2017级"

 }

}

以上就是本次介绍的全部相关知识点,感谢大家的学习和对三水点靠木的支持。

PHP 相关文章推荐
解决phpmyadmin 乱码,支持gb2312和utf-8
Nov 20 PHP
PHP中常用的转义函数
Feb 28 PHP
模板引擎smarty工作原理以及使用示例
May 25 PHP
10款实用的PHP开源工具
Oct 23 PHP
PHP连接MySQL进行增、删、改、查操作
Feb 19 PHP
[原创]PHP正则匹配中英文、数字及下划线的方法【用户名验证】
Aug 01 PHP
PHP实现将标点符号正则替换为空格的方法
Aug 09 PHP
PHP实现求两个字符串最长公共子串的方法示例
Nov 17 PHP
PHP实现二维数组中的查找算法小结
Jun 09 PHP
详解php中curl返回false的解决办法
Mar 18 PHP
PHP pthreads v3下worker和pool的使用方法示例
Feb 21 PHP
laravel中Redis队列监听中断的分析
Sep 14 PHP
PHP架构及原理知识点详解
Dec 22 #PHP
Laravel 验证码认证学习记录小结
Dec 20 #PHP
php文件上传原理与实现方法详解
Dec 20 #PHP
PHP使用PDO实现mysql防注入功能详解
Dec 20 #PHP
laravel框架数据库操作、查询构建器、Eloquent ORM操作实例分析
Dec 20 #PHP
PHP+fiddler抓包采集微信文章阅读数点赞数的思路详解
Dec 20 #PHP
PHP的图像处理实例小结【文字水印、图片水印、压缩图像等】
Dec 20 #PHP
You might like
JS判断移动端访问设备并加载对应CSS样式
2014/06/13 Javascript
Javascript Object 对象学习笔记
2014/12/17 Javascript
浅析Node.js中的内存泄漏问题
2015/06/23 Javascript
理解Javascript文件动态加载
2016/01/29 Javascript
JS+CSS实现鼠标经过弹出一个DIV框完整实例(带缓冲动画渐变效果)
2016/03/25 Javascript
jQuery的框架介绍
2016/05/11 Javascript
关于Javascript中defer和async的区别总结
2016/09/20 Javascript
微信小程序的动画效果详解
2017/01/18 Javascript
node.js学习之断言assert的使用示例
2017/09/28 Javascript
npm 更改默认全局路径以及国内镜像的方法
2018/05/16 Javascript
vue拖拽排序插件vuedraggable使用方法详解
2020/08/21 Javascript
vue cli3.0 引入eslint 结合vscode使用
2019/05/27 Javascript
JS实现点击发送验证码 xx秒后重新发送功能
2019/07/30 Javascript
vue中实现点击变成全屏的多种方法
2020/09/27 Javascript
python常见的格式化输出小结
2016/12/15 Python
Python3 循环语句(for、while、break、range等)
2017/11/20 Python
tensorflow更改变量的值实例
2018/07/30 Python
python复制列表时[:]和[::]之间有什么区别
2018/10/16 Python
python 搭建简单的http server,可直接post文件的实例
2019/01/03 Python
详解Python计算机视觉 图像扭曲(仿射扭曲)
2019/03/27 Python
Python 实现交换矩阵的行示例
2019/06/26 Python
python3+openCV 获取图片中文本区域的最小外接矩形实例
2020/06/02 Python
在Pytorch中使用Mask R-CNN进行实例分割操作
2020/06/24 Python
python3.7添加dlib模块的方法
2020/07/01 Python
解决Keras的自定义lambda层去reshape张量时model保存出错问题
2020/07/01 Python
新西兰领先的内衣店:Bendon Lingerie新西兰
2018/07/11 全球购物
FLIR美国官网:热成像, 夜视和红外摄像系统
2018/07/13 全球购物
请描述一下”is a”关系和”has a”关系
2015/02/03 面试题
工程招投标邀请书
2014/01/26 职场文书
巾帼建功标兵事迹材料
2014/05/11 职场文书
邹越感恩父母演讲稿
2014/08/28 职场文书
买房子个人收入证明
2014/10/12 职场文书
CSS3实现的水平标题菜单
2021/04/14 HTML / CSS
SQL语法CONSTRAINT约束操作详情
2022/01/18 MySQL
Android基于Fresco实现圆角和圆形图片
2022/04/01 Java/Android
Tomcat项目启动失败的原因和解决办法
2022/04/20 Servers