php算法排列组合,求33选6用php代码实现。 10

php算法排列组合,求33选6的全部排列组合用php代码实现。... php算法排列组合,求33选6的全部排列组合用php代码实现。 展开
 我来答
老李浅谈PHP开发
2017-06-19 · TA获得超过123个赞
知道小有建树答主
回答量:210
采纳率:0%
帮助的人:41.5万
展开全部
<?php

// 阶乘
function factorial($n) {
return array_product(range(1, $n));
}

// 排列数
function A($n, $m) {
return factorial($n)/factorial($n-$m);
}

// 组合数
function C($n, $m) {
return A($n, $m)/factorial($m);
}

// 排列
function arrangement($a, $m) {
$r = array();

$n = count($a);
if ($m <= 0 || $m > $n) {
return $r;
}

for ($i=0; $i<$n; $i++) {
$b = $a;
$t = array_splice($b, $i, 1);
if ($m == 1) {
$r[] = $t;
} else {
$c = arrangement($b, $m-1);
foreach ($c as $v) {
$r[] = array_merge($t, $v);
}
}
}

return $r;
}

// 组合
function combination($a, $m) {
$r = array();

$n = count($a);
if ($m <= 0 || $m > $n) {
return $r;
}

for ($i=0; $i<$n; $i++) {
$t = array($a[$i]);
if ($m == 1) {
$r[] = $t;
} else {
$b = array_slice($a, $i+1);
$c = combination($b, $m-1);
foreach ($c as $v) {
$r[] = array_merge($t, $v);
}
}
}

return $r;
}


// ====== 测试 ======
$a = array("A", "B", "C", "D");

$r = arrangement($a, 2);
var_dump($r);

$r = A(4, 2);
echo $r."\n";

$r = combination($a, 2);
var_dump($r);

$r = C(4, 2);
echo $r."\n";
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
abccccaf
2017-06-19 · TA获得超过845个赞
知道小有建树答主
回答量:912
采纳率:86%
帮助的人:260万
展开全部
33 选 6是什么意思 说明白点
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式