笛卡尔积算法,二维数组矩阵算法PHP


递归实现

$arr	= array(
	array(1),
	array(2,3),
	array(4,5,6)
);
fun($arr);
print_r($res);
function fun($arr, $tmp = array())
{
	foreach(array_shift($arr) AS $v)
	{
		$tmp[]	= $v;
		if($arr)
		{
			fun($arr, $tmp);
		}
		else
		{
			$GLOBALS["res"][]	= $tmp;
		}
		array_pop($tmp);
	}
}


foreach,遍历每个元素元素,进行递归。

如:

1,2      4 5 6   => 1,2,4     1,2,5    1,2,6

1,3      4 5 6   => 1,3,4     1,3,5    1,3,6



http://bbs.csdn.net/topics/380239639

举例:

$arr = array(
    'a'=>array('a1','a2','a3'),
    'b'=>array('b1','b2','b3'),
    'c'=>array('c1','c2','c3'),

	//..........多行......
);

fun($arr);
//print_r($res);

echo '<table width="150px" border="1">';
$j=0;
	echo "<tr>";
	echo "<td>序号</td>";
	foreach($arr as $k=>$v)
	{		
		echo "<td>".$k."</td>";
	}	
	echo "</tr>";
foreach($res as $v)
{
	echo "<tr>";
	$i=0;
	$j++;
	echo "<td>".$j."</td>";
	foreach($arr as $value)
	{		
		echo "<td>".$v[$i]."</td>";
		$i++;
	}	
	echo "</tr>";
}
echo '</table>';

function fun($arr, $tmp = array())
{
	
	foreach(array_shift($arr) AS $v)
	{
		$tmp[]	= $v;		
		if($arr)
		{
			fun($arr, $tmp);
		}
		else
		{
			$GLOBALS["res"][]	= $tmp;
		}
		array_pop($tmp);
	}
}

exit;


非递归:(其实也类似递归)

$arr = array(
array('a1','a2',),
array('c1','c2',),
array('d1','d2','d3'),
//......省略其它元素(也可以是数组),
);
$r = Descartes( $arr );

print_r($r);
function Descartes() {
	$t = func_get_args();
	if(func_num_args() == 1) return call_user_func_array( __FUNCTION__, $t[0] );
	$a = array_shift($t);
	if(! is_array($a)) $a = array($a);
	$a = array_chunk($a, 1);
		do {
			$r = array();
			$b = array_shift($t);
			if(! is_array($b)) $b = array($b);
			foreach($a as $p)
			foreach(array_chunk($b, 1) as $q)
			$r[] = array_merge($p, $q);
			$a = $r;
		}
		while($t);
	return $r;
}

exit;








  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值